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PHP 是 一 种 执行 于 服务 器 端 、 媒 入 HTML 文档 的 通用 开源 脚本 语言 ， 其 语法 吸收 了 C 
语言 、Java 语言 和 Perl 语言 的 特点 ， 易 于 学 习 ， 使 用 广泛 ， 主 要 适用 于 Web 开发 领域 。 

MySQL 是 最 流行 的 关系 型 数据 库 管理 系统 ， 是 在 Web 应 用 方面 最 好 的 关系 数据 库 管 
理 系 统 应 用 软件 之 一 ， 具 有 体积 小 、 速 度 快 、 总 体 拥有 成 本 低 、 源 码 开放 等 特点 。 

Apache 是 世界 上 使 用 量 排名 第 一 的 Web 服务 器 软件 , 它 可 以 运行 在 几乎 所 有 广泛 使 用 
的 计算 机 平台 上 ， 其 跨 平 台 性 和 安全 性 使 其 被 广泛 使 用 ， 是 最 流行 的 Web 服务 器 端 软件 。 

MySQL 搭配 PHP 和 Apache， 可 以 组 成 良好 的 开发 环境 ， 该 技术 已 成 为 目前 国内 中 小 
型 网 站 普遍 采用 的 网 站 开发 方式 。 

本 书 作为 计算 机 网 络 专业 “动态 网 站 开发 ”课程 的 授课 教材 。 分 为 七 个 模块 ， 前 两 个 
模块 介绍 网 站 开发 环境 的 配置 及 PHP 的 基本 语法 规范 ， 后 五 个 模块 是 五 个 网 站 开发 实例 。 
在 教学 过 程 中 ， 教 师 可 以 根据 教学 需要 来 安排 实例 教学 顺序 或 者 做 适当 的 删 减 。 通 过 学 习 ， 
使 学 生 能 够 掌握 网 站 的 设计 流程 ， 明 白 网 站 的 运行 过 程 和 工作 原理 。 

各 模块 的 内 容 概括 如 下 。 

模块 一 : 引导 学 生 进 入 PHP 开发 领域 ， 了 解 Web 开发 需要 的 各 种 构件 ， 掌 握 基 于 数据 
库 的 动态 网 站 运行 原理 ， 以 及 PHP 的 功能 、 开 发 优势 和 发 展 趋势 ， 掌 握 在 Windows 系统 下 
安装 PHPnow 的 操作 方法 。 

模块 二 : 以 小 实例 的 形式 着 重 介绍 PHP 的 基本 语法 ， 包 括 语言 风格 、 数 据 类 型 、 变 量 、 
常量 、PHP 运算 符 和 表达 式 的 内 容 ; 还 有 PHP 的 语言 结构 ， 包 括 条件 语 句 、 循 环 语句 等 流 
程控 制 结构 和 函数 声明 与 应 用 的 各 个 环节 ; 介绍 PHP 的 数组 与 数据 结构 的 应 用 。 

模块 三 : 讲解 “价格 查询 系统 ”实例 ,重点 介绍 以 Dreamweaver 进行 PHP 开发 的 流程 ， 
搭建 PHP 动态 系统 开发 平台 的 方法 ， 检 查 、 编 辑 数据 库 记录 的 操作 方法 。 

模块 四 : 讲解 “用 户 管理 系统 ”实例 ， 按 照 软件 开发 的 基本 过 程 ， 以 系统 的 需求 分 析 、 
数据 库 设计 和 系统 的 设计 为 基本 开发 步骤 ， 详 细 介 绍 用 户 管理 系统 开发 的 全 部 过 程 ， 通 过 
对 用 户 注 册 信 息 的 统计 ， 可 以 让 管理 员 了 解 到 网 站 的 访问 情况 ， 通 过 对 用 户 权限 的 设置 ， 
可 以 限制 其 对 网 站 页 面 的 访问 。 

模块 五 :讲解 “留言 簿 管理 系统 ”实例 ， 留 言 簿 的 功能 主要 是 实现 网 站 的 访问 者 与 网 
站 管理 者 的 交互 ， 主 要 涉及 数据 库 留言 信息 的 插入 、 回 复 和 修改 信息 等 操作 。 

模块 六 : 讲解 “在 线 投票 管理 系统 ”实例 。 包 括 投票 功能 、 投 票 处 理 功 能 和 显示 投票 
结果 功能 。 通 过 投票 者 单 击 “ 投 票 ”按钮 ， 激 活 投票 处 理 功能 ， 对 服务 器 传 来 的 数据 做 出 
相应 的 处 理 ， 先 判断 用 户 选 择 的 是 哪 一 项 ， 并 累计 相应 的 字段 值 ， 然 后 更 新 数据 库 ， 最 后 
显示 投票 的 结果 。 
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模块 七 : 讲解“ 新闻 管理 系统 ”实例 ， 主 要 实现 对 新 闻 的 分 类 和 发 布 ， 其 作用 就 是 在 
网 上 传播 信息 ， 通 过 对 新 闻 的 不 断 更 新 ， 使 用 户 及 时 了 解 行业 信息 、 企 业 状况 以 及 其 他 需 
要 了 解 的 知识 。 主 要 操作 包括 访问 者 的 新 闻 查 询 功 能 ， 系 统管 理 员 对 新 闻 的 新 增 、 修 改 和 
删除 功能 。 

本 书 由 史 香 雯 、 孙 屹 和 徐 俊 强 合作 编写 完成 ， 其 中 模块 一 、 模 块 二 、 模 块 三 由 徐 俊 强 
编写 ， 模 块 四 、 模 块 五 由 史 香 雯 编写 ， 模 块 六 、 模 块 七 由 孙 屹 编写 。 本 书 的 插图 、 整 体 设 
计 及 教材 成 书 的 编排 等 工作 由 徐 俊 强 完成 。 

在 本 书 的 编写 过 程 中 ， 得 到 了 天 津 市 劳动 经 济 学校 、 天 津 市 人 力 资 源 和 社会 保障 局 第 
二 高 级 技工 学 校 相关 部 门 及 领导 的 关心 和 大 力 支持 ， 得 到 了 学 校 计 算 机 教学 部 专业 课 教 师 
的 热心 帮助 和 指导 , 校 企 合作 单位 之 一 一 一 华为 (天 津 ) 科 技 有 限 公司 的 高 级 工程 师 姚 文 林 对 
本 教材 的 编写 提出 了 意见 和 建议 ， 计 算 机 教学 部 张 静 老 师 对 本 书 的 出 版 做 了 大 量 的 工作 ， 
在 此 一 并 表示 衷心 的 感谢 。 

本 书 在 编写 过 程 中 参考 了 一 些 PHP + MySQL 网 站 开发 的 书籍 , 并 从 百度 文库 及 有 关 网 
站 (如 http:/www.w3school.com.cn) 获 取 了 相关 的 知识 。 由 于 作者 水 平 所 限 ， 书 中 难免 会 存在 
一 些 错误 ， 诚 请 谅解 ， 并 期 待 您 的 批评 和 指正 。 

联系 邮箱 : tjljjlkb@126.com 
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PHP 网 站 开发 环境 的 配置 





PHP 是 一 种 多 用 途 脚 本 语言 ， 适 合 于 Web 应 用 程序 的 开发 。 使 
用 PHP 强大 的 扩展 性 ， 可 以 在 服务 器 端 连 接 Java 应 用 程序 ， 还 可 以 
与 .NET 建立 有 效 的 沟通 甚至 进行 更 广阔 的 扩展 ， 从 而 可 以 建立 一 个 
强大 的 环境 ， 以 充分 利用 现 有 的 和 其 他 技术 开发 的 资源 。 

开源 和 跨 平台 的 特性 ， 使 得 PHP 架构 能 够 快速 、 高 效 地 开发 出 
可 移植 的 、 跨 平台 的 、 具 有 强大 功能 的 企业 级 Web 应 用 程序 。 在 使 
用 PHP 进行 网 站 开发 之 前 ， 需 要 在 操作 系统 上 搭建 一 个 适合 PHP 开 
发 的 操作 平台 。 使 用 Windows 自 带 的 IIS 服务 器 或 者 单独 安装 一 个 
Apache 服务 器 ， 都 可 以 实现 PHP 的 解析 运行 。 对 于 刚 入 门 的 新 手 而 
言 , PHP 的 开发 环境 推荐 使 用 Apache( 服 务 器 ) + Dreamweaver( 网 页 开 
发 软件 ) + MySQL( 数 据 库 ) 组 合 。 

本 模块 将 重点 介绍 PHP 网 站 开发 环境 的 配置 。 


。 本 模块 的 任务 重点 。 
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二 1| 了 解 PHP 开发 环境 





4 -PHP 


PHP 全 称 为 Personal Home Page， 是 一 种 用 于 创建 动态 Web 页 面 的 服务 端 脚本 语言 。 
如 同 ASP 和 ColdFusion， 用 户 可 以 混合 使 用 PHP 和 HTML 编写 Web 页 面 ， 当 访问 者 浏览 
到 该 页 面 时 ,服务 端 会 首先 对 页 面 中 的 PHP 命令 进行 处 理 ,然后 把 处 理 后 的 结果 连同 HTML 
内 容 一 起 传送 到 访问 端的 浏览 器 。 

与 ASP 或 ColdFusion 不 同 的 是 ，PHP 是 一 种 源 代码 开放 的 程序 ， 拥 有 很 好 的 跨 平台 兼 
容 性 。 用 户 可 以 在 Windows NT 系统 以 及 许多 版 本 的 Unix 系统 上 运行 PHP, 而 且 可 以 将 PHP 
作为 Apache 服务 器 的 内 置 模块 或 者 CGI 程序 来 运行 。 

除了 能 够 精确 地 控制 Web 页 面 的 显示 内 容 之 外 ,用 户 还 可 以 使 用 PHP 发送 HTTP 报头 。 
用 户 可 以 通过 PHP 设置 Cookies， 管 理 用 户 身 份 识别 ， 并 对 用 户 浏览 页 面 进行 重 定向 。 

PHP 具有 非常 强大 的 数据 库 支持 功能 ， 能 够 访问 几乎 目前 所 有 较为 流行 的 数据 库 系 统 。 
此 外 ，PHP 可 以 与 多 个 外 接 库 集成 ， 为 用 户 提供 更 多 的 实用 功能 ， 如 生成 PDF 文件 等 。 

用 户 可 以 直接 在 Web 页 面 中 输入 PHP 命令 代码 ， 因 而 不 需要 任何 特殊 的 开发 环境 。 在 
Web 页 面 中 ， 所 有 PHP 代码 都 被 放置 在 “<?php” 和 “?>” 中 。 此 外 ， 用 户 还 可 以 选择 使 
用 诸如 <SCRIPT LANGUAGE=“php”></SCRIPT> 等 的 形式 。PHP 引擎 会 自动 识别 并 处 理 页 
面 中 所 有 位 于 PHP 定 界 符 之 间 的 代码 。 

PHP 脚本 语言 的 语法 结构 与 C 语言 和 Perl 语言 的 语法 风格 非常 相似 。 用 户 在 使 用 变量 
前 ， 不 需要 对 变量 进行 声明 。 使 用 PHP 创建 数组 的 过 程 也 非常 简单 。PHP 还 具有 基本 的 面 
向 对 象 组 件 功能 ， 便 于 用 户 有 效 组 织 和 封装 自己 编写 的 代码 。 


1.2 Apache HTTP Server 


Apache HTTP Server 简称 Apache, 是 Apache 软件 基金 会 的 一 个 开放 源码 的 网 页 服务 器 ， 
可 以 在 大 多 数 计算 机 操作 系统 中 运行 ， 由 于 其 跨 平台 和 安全 性 而 被 广泛 使 用 ， 因 而 成 为 最 
流行 的 Web 服务 器 端 软件 之 一 。 Apache HTTP Server 是 世界 上 使 用 量 排名 第 一 的 Web 服务 
器 软件 。 它 可 以 运行 在 几乎 所 有 广泛 使 用 的 计算 机 平台 上 。 

Apache 源 于 NCSA httpd 服务 器 ， 经 过 多 次 修改 ， 成 为 世界 上 最 流行 的 Web 服务 器 软 
件 之 一 。Apache 取 自 “A Patchy Server” 的 读音 ,意思 是 充满 补丁 的 服务 器 ， 因 为 它 是 自由 
软件 ， 所 以 不 断 有 人 来 为 它 开发 新 的 功能 、 新 的 特性 ， 修 改 原来 的 缺陷 。Apache 的 特点 是 
简单 、 速 度 快 、 性 能 稳定 ， 并 可 作为 代理 服务 器 使 用 。 


Apache 本 来 只 用 于 小 型 或 试验 Internet 网 络 , 后 来 逐步 扩充 到 各 种 Unix 系统 中 ,对 Linux 
的 支持 更 是 相当 完美 。 Apache 有 多 种 产品 , 可 以 支持 SSL 技术 , 支持 多 个 虚拟 主机 。Apache 
是 以 进程 为 基础 的 结构 ， 进 程 要 比 线程 消耗 更 多 的 系统 开销 ， 不 太 适 合 于 多 处 理 器 环境 ， 
因此 ， 在 一 个 Apache Web 站 点 扩容 时 ， 通 常 是 增加 服务 器 或 扩充 群集 节点 ， 而 不 是 增加 处 
理 器 。 到 目前 为 止 , Apache 仍然 是 世界 上 用 得 最 多 的 Web 服务 器 , 市 场 占有 率 达 60% 左 右 。 
世界 上 很 多 著名 的 网 站 ， 如 Amazon、Yahoo!l、W3 Consortium、Financial Times 等 ， 都 是 
Apache 的 产物 ， 它 的 成 功 之 处 主要 在 于 它 的 源 代 码 开放 、 有 一 支 开放 的 开发 队伍 、 支 持 跨 
平台 的 应 用 (可 以 运行 在 几乎 所 有 的 Unix、Windows、Linux 系统 平台 上 ) 以 及 它 的 可 移植 性 
等 方面 。 

Apache 的 诞生 极 富有 戏剧 性 。 当 NCSA WWW 服务 器 项 目 停顿 后 ， 那 些 使 用 NCSA 
WWW 服务 器 的 人 们 开始 交换 他 们 用 于 该 服务 器 的 补丁 程序 ， 他 们 也 很 快 认识 到 成 立 管理 
这 些 补丁 程序 的 论坛 是 必要 的 。 就 这 样 ， 诞 生 了 Apache Group， 后 来 ， 这 个 团体 在 NCSA 
的 基础 上 创建 了 Apache。 

Apache Web 服务 器 软件 拥有 以 下 特性 : 
支持 最 新 的 HTTP 1.1 通信 协议 。 
拥有 简单 而 强 有 力 的 基于 文件 的 配置 过 程 。 
支持 通用 网 关 接 口 。 
支持 基于 IP 和 基于 域名 的 虚拟 主机 。 
支持 多 种 方式 的 HTTP 认证 。 
集成 Perl 处 理 模块 。 
集成 代理 服务 器 模块 。 
支持 实时 监视 服务 器 状态 和 定制 服务 器 日 志 。 
支持 服务 器 端 包含 指令 (SSD。 
支持 安全 Socket 层 (SSL)。 
提供 用 户 会 话 过 程 的 跟踪 。 
支持 FastCGI。 


1.3 ”MySQL 关系 型 数据 库 管 理 系统 


MySQL 由 瑞典 MySQL AB 公司 开发 ， 目 前 属于 Oracle 公司 。MySQL 是 目前 最 流行 的 
关系 型 数据 库 管理 系统 , 在 Web 应 用 方面 , MySQL 是 最 好 的 关系 数据 库 管 理 系 统 应 用 软件 
之 一 。MySQL 是 一 种 关联 数据 库 管 理 系统 ， 关 联 数据 库 将 数据 保存 在 不 同 的 表 中 ， 而 不 是 
将 所 有 数据 放 在 一 个 大 仓库 内 ， 这 样 就 提高 了 速度 ， 并 增加 了 灵活 性 。 

MySQL 所 使 用 的 SQL 语言 ， 是 用 于 访问 数据 库 的 最 常用 的 标准 化 语言 。MySQL 软件 


轴 员 加 避 当 对 习 异 习 dHd 
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采用 了 双 授 权 政 策 ， 分 为 社区 版 和 商业 版 。 由 于 其 体积 小 、 速 度 快 、 总 体 拥有 成 本 低 ， 尤 
其 是 开放 源码 这 一 特点 ， 使 得 一 般 中 小 型 网 站 的 开发 都 愿意 选择 MySQL 作为 网 站 数据 库 。 
其 中 ， 社 区 版 的 性 能 卓越 ， 搭 配 PHP 和 Apache 可 组 成 良好 的 开发 环境 。 

MySQL 系统 的 特性 如 下 : 





使 用 C 和 C++ 编写 ， 并 使 用 了 多 种 编译 器 进行 测试 ， 保 障 了 源 代码 的 可 移植 性 。 
支持 AIX、FreeBSD、HP-UX、Linux、Mac OS、NovellNetware、OpenBSD、OS/2 
Wrap、Solaris、Windows 等 多 种 操作 系统 。 

为 多 种 编程 语言 提供 了 API。 这 些 编程 语言 包括 C、C++、 Python、 Java、 Perl、 PHP、 
Eiffel、Ruby 和 Tcl 等 。 

支持 多 线程 ， 可 充分 利用 CPU 资源 。 

拥有 优化 的 SQL 查询 算法 ， 可 有 效 地 提高 查询 速度 。 

既 能 够 作为 一 个 单独 的 应 用 程序 应 用 在 客户 端 服务 器 网 络 环境 中 ， 也 能 够 作为 一 
个 库 而 嵌入 到 其 他 的 软件 中 。 

提供 多 语言 支持 ， 常 见 的 编码 如 中 文 的 GB2312、BIG5， 日 文 的 Shift_ JIS 等 ， 都 
可 以 用 作 数 据 表 名 和 数据 列 名 。 

提供 TCPIP、ODBC 和 JDBC 等 多 种 数据 库 连接 途径 。 

提供 用 于 管理 、 检 查 、 优 化 数据 库 操作 的 管理 工具 。 

支持 大 型 的 数据 库 。 可 以 处 理 拥有 上 千 万 条 记录 的 大 型 数据 库 。 
支持 多 种 存储 引擎 。 

是 开源 的 ， 所 以 不 需要 支付 额外 的 费用 。 

使 用 标准 的 SQL 数据 语言 形式 。 

对 PHP 有 很 好 的 支持 ，PHP 是 目前 最 流行 的 Web 开发 语言 。 

可 以 定制 ， 采 用 了 GPL 协议 ， 可 以 修改 源码 来 开发 自己 的 MySQL 系统 。 








和 2_ PHP 开发 环境 的 安装 和 配置 


PHPnow 是 Win32 下 绿色 免费 的 Apache + PHP + MySQL 环境 套件 包 。 安装 简易 , 可 快 
速 搭建 支持 虚拟 主机 的 PHP 环境 。 附 带 PnCp.cmd 控制 面板 ， 可 帮助 我 们 快速 地 配置 自己 
的 套件 ， 使 用 非常 方便 ， 特 别 适合 普通 用 户 使 用 PHP 学 习 动 态 网 页 的 设计 。 

PHPnow 是 绿色 的 ， 解 压 后 执行 Setup.cmd 初始 化 ， 即 可 得 到 一 个 Apache + PHP + 
MySQL 环境 ， 然 后 就 可 以 直接 安装 Discuz!、PHPWind、DeDe、WordPress 等 程序 。 

PHPnow 提供 安全 快速 的 PHP 开发 解决 方案 ，PHPnow 框架 采用 国际 公认 的 MVC 思 
想 ， 采 用 OOP 方式 开发 ， 易 扩展 、 稳 定 ， 具 有 超级 强大 的 负载 能 力 ， 能 做 企业 级 的 安全 部 





署 ， 适 合 重点 发 展现 代 安 全 快速 的 互联 网 应 用 程序 开发 。 
以 下 为 PHPnow 1.5.6 版 本 环境 的 搭建 过 程 。 
9 把 从 http://www.phpnow.org/download.html 下 载 的 PHPnow-1.5.6.zip 解压 到 你 
想 要 的 盘 中 ， 这 里 是 解压 到 了 C:\Apache， 如 图 1-1 所 示 。 





文件 @) 编辑 EE) 查看 W) 收藏) 工具 CI) 帮助 0 
扫 EE- 日 计 吕 搜索 杞 文 #f 天 回 - 


Bc: Wpache 


文件 和 文件 夹 任务 多 


四 8 娃 一 人 新 文件 严 
全 将 这 人 文件 严 发 到 
忆 共享 此 六 件 夹 


详细 信息 
Apache 


忻 夹 
鲍 有 m 





图 1-1 PHPnow 的 解压 结果 


解压 后 执行 Setup.cmd， 根 据 提示 进行 操作 ， 程 序 将 会 调用 Init.cmd 初始 化 。 
说 明 : 成 功 初始 化 后 , Init.cmd 会 自动 改名 为 Init.cm_。 如 有 必要 , 可 将 其 改名 为 Init.cmd 
重新 初始 化 。 重 新 初始 化 不 会 丢失 网 站 数据 ， 仅 仅 是 对 配置 进行 复位 。 
执行 Setup.cmd， 出 现 如 图 1-2 所 示 的 窗口 ， 分 别 执行 < 推荐 > 选项 并 按 Enter 键 ， 开 始 进 
行 解压 。 





组 件 版 本 选择 





Ll | 








图 1-2 组 件 版 本 的 选择 


解压 完成 后 ， 接 下 来 询问 是 否 初始 化 ， 输 入 “y” 后 按 Enter 键 ， 开 始 执行 初 
始 化 命令 mitcmd， 如 图 1-3 所 示 。 


1 红 匡 
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hpMyAdnin\contrib\packaging \Fedora 
hpMyAdnin\contrib\packaging 

‘phpHyAdnin \contrib 

‘phpHyAdnin 


nodul 
28\ic all 


include 


28\conf 
@\cgi-bin 
bin\iconv 
bin 


168548882 
: 18827256 


Init.cnd 初 











图 1-3 组 件 的 初始 化 
成 功 初 始 Init.cmd 后 ， 如 图 1-4 所 示 ， 开 始 为 MySQL 的 root 用 户 设 置 密码 。 


[ -jx 


Apache ... 


Apache 


Apac 


not 用 


: 123456 











图 1-4 设置 MySQL 管理 用 户 root 的 密码 


输入 MySQL 的 密码 (这 里 输入 的 是 “123456”)， 执 行 完 这 一 步 后 ， 文 件 夹 的 
文件 变 为 如 图 1-5 所 示 的 模样 。 


篇 c: vapache 

文件 EE) 辆 辑 了 查看 Q) 收 着 好 工具 中 硕 助 吕 
i 所 -局 -会 | 万 抽 已 文 H 夫 | 回 - 

地 址 四 ) | 加 Cc:\ hpache 


文件 和 文件 夫 企 务 | 时 | | 


中 创 胖 一 个 新 廊 件 夹 Apache-20 htdocs my7S9L-5. 
全 将 党 文人 发布 到 





世 共 节 此 文件 天 到 | 加 


Pronds ZendDpti... 





更 新 日 志 ”关于 逢 态 升级 方法 





1-5 组 件 安装 完成 后 的 结果 


如 果 要 钊 载 上 面 的 PHPnow， 可 执行 文件 夹 中 PnCmds 文件 夹 里 的 Stop.cmd 
文件 ， 如 图 1-6 所 示 。 


篇 C:\apache\PnCads 
文件 @) 编 癌 EE) 查看 WW) 收藏 工具 CI) 帮助 0D 
加 扫 - 如- 舍 甩 雪 索 杞 文人 来 回 - 
地 址 DD) 局 C \Apache\PnCads 
As start. cmd a_Start. cmd 
文件 和 文件 夹 任 盆 st Dene Ne 
而 重合 名 这 个 文件 
励 移 上 这 个 文件 
四 号 8 这 个 文件 
全 将 这 个 文件 发 布 到 
Yeb Start. cnd 
> 以 电子 最 件 形式 发 送 5 Windows NT 命令 类 本 
此 文件 1 地 
浪打 印 这 个 文件 
XX 出 隆 这 个 文件 


绝对 强制 逆 载 . ca 
Windows MT 命令 羯 本 
2 





1-6 ”PHPnow 的 命令 文件 夹 


然后 再 把 先前 解压 的 文件 夹 删 掉 就 行 了 。 

在 05 步 密码 设置 完成 后 , 系统 会 自动 地 在 浏览 器 中 打开 如 图 1-7 所 示 的 页 面 ， 
然后 在 “MySQL 用 户 密码 ”右边 的 文本 框 中 ， 输 入 先前 设置 的 MySQL 用户 root 
的 密码 “123456” 即 可 。 


dHd 


器 出 器 司 当 江 书屋 
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文件 到 编辑 了 ) 查看 中 收 豪 和 ) 工具 GD) 天助 D 
@P 良 -日 - 固 国 名 记 扫 雪 去 收 VW 如 全 -名 加- 申 记 
地 让 四 ) | 莉 http://127.0.0. 1/index php <* 久 入 关 扫 司 搜索 口 国 











127.0.0.1 为 人 只 玉 过问? 


#Let's PHP now ! 


SERVER_NAME | 127.0.0.1 
SERVER_ADDR:PORT | 127.0.0.1:80 
SERVER_SOFTWARE | Apache/2.0.63 (Win32) PHP/5.2.14 
PHP_SAPI | apachezhandler 
php.ini | C:Apache\php-5.2.14-Win32\php-apache2handler.ini 
网 站 主 目录 | C:/Apache/htdocs 
Server Date / Time | 2014-08-10 09:34:28 
other Links | phpinfo0 | phpMyAdmin 


























Zend Optimizer | Yes/3.3.3 
MySQL 支 持 | Yes / dient lib version 5.0.90 
GD library | Yes / bundled (2.0.34 compatible) 
eAccelerator | No 

















MySQL 服务 器 llocalhost MySQL 数据 库 名 


MySQL 用 户 各 | [root | wsor Rpgm | 









































服务 器 localhost OK (5.0.90-community-nt) 
数据 库 test OK 

















/ Copyleft ! 2007-? by PHPnow.org 


| 





1-7 index.php 网 页 的 效果 


到 这 里 ，PHP 的 环境 就 搭建 完成 了 。 

把 自己 的 PHP 网 站 放 到 PHPnow-1.5.6/htdocs 文件 夹 中 ， 就 可 在 下 网 址 栏 上 输入 
“http://127.0.0.1/index.php” 进 行 访问 了 (这 里 是 访问 网 站 根 目录 上 的 index.php 网 页 ， 根 据 
经 验 ， 建 议 读者 在 建站 调试 过 程 中 ， 保 存 文档 时 不 要 使 用 index.php 这 个 文件 名 )。 





Cookie 有 时 也 用 其 复数 形式 Cookies， 指 某 些 网 站 为 了 辨别 用 户 身份 、 进 行 Session 
跟踪 而 储存 在 用 户 本 地 终端 上 的 数据 (通常 经 过 加 密 )。RFC2109 和 RFC2965 的 定义 都 已 废 
弃 ， 最 新 取代 的 规范 是 RFC6265。Cookie 由 服务 器 端 生成 ， 发 送 给 User-Agent( 一 般 是 浏览 
器 )， 浏 览 器 会 将 Cookie 的 key/value 保存 到 某 个 目录 下 的 文本 文件 内 ， 下 次 请 求 同 一 网 站 
时 ， 就 发 送 该 Cookie 给 服务 器 (前 提 是 浏览 器 设置 为 启用 Cookie)。 

FastCGI 是 语言 无 关 的 、 可 伸缩 架构 的 CGI 开放 扩展 , 其 主要 行为 是 将 CGI 解释 器 进 
程 保持 在 内 存 中 ， 并 因此 获得 较 高 的 性 能 。 

Socket 又 称 “ 套 接 字 ”， 应 用 程序 通常 通过 “ 套 接 字 ” 向 网 络 发 出 请 求 或 者 应 答 网 络 


请 求 。 

关系 数据 库 管理 系统 RDBMS(Relational Database Management System) 包 括 相互 联系 
的 数据 集合 (数据 库 ) 和 存 取 这 些 数据 的 一 套 程 序 ( 数 据 库 管 理 系统 软件 )。 关 系数 据 库 管 理 系 
统 就 是 管理 关系 数据 库 ， 并 将 数据 组 织 为 相关 的 行 和 列 的 系统 。MySQL、SQL Server 都 是 
一 种 关系 数据 库 管理 系统 (RDBMS)。 

数据 库 管 理 系统 的 专门 运算 包括 选择 运算 、 投 影 运 算 和 连接 运算 。 

多 线程 ”在 一 个 程序 中 ， 这 些 独立 运行 的 程序 片段 叫 作 “线程 ”(Thread)， 利 用 它 编程 
的 概念 就 叫 作 “多 线程 处 理 (Multithreading)”。 具 有 多 线程 能 力 的 计算 机 因 有 硬件 支持 而 能 
够 在 同一 时 间 执 行 多 个 线程 ， 进 而 可 以 提升 整体 处 理性 能 。 

MVC 全 名 是 Model-View-Controller， 是 模型 (Model)- 视 图 (View)- 控 制 器 (Controller) 
的 缩写 ， 作 为 一 种 软件 设计 典范 ， 用 一 种 业务 逻辑 、 数 据 、 界 面 显示 分 离 的 方法 来 组 织 代 
码 ， 将 业务 逻辑 聚集 到 一 个 部 件 里 面 ， 在 改进 和 个 性 化 定制 界面 及 用 户 交互 的 同时 ， 不 需 
要 重新 编写 业务 逻辑 。 

面向 对 象 编程 OOP (Object Oriented Programming， 面 向 对 象 程序 设计 ) 是 一 种 计算 机 
编程 架构 。OOP 的 一 条 基本 原则 是 ， 计 算 机 程序 是 由 单个 能 够 起 到 子 程序 作用 的 单元 或 对 
象 组 合 而 成 的 。 


| 剧 二 
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员 虽 可 品 当 对 习 异 


模块 二 


PHP 的 基本 语法 





PHP 是 一 种 创建 动态 交互 性 站 点 的 强 有 力 的 服务 器 端 脚本 语言 。 
既然 是 脚本 语言 ， 那 么 ， 在 使 用 之 前 ， 我 们 就 要 学 习 PHP 的 基本 语 
法 ， 只 有 掌握 了 基本 语法 ， 才 可 以 方便 地 进行 动态 网 站 的 开发 。 

PHP 语法 非常 类 似 于 Perl 和 C 的 语法 ， 有 相关 经 验 的 读者 可 以 
非常 轻松 地 掌握 。 

本 章 就 介绍 一 些 PHP 的 基本 语法 ， 包 括 变量 、 常 量 、 运 算 符 、 
控制 语句 以 及 数组 等 ， 通 过 学 习 这 些 基 础 知识 ， 使 读者 能 更 深入 地 了 
解 PHP， 并 能 在 后 面 的 章节 中 轻松 地 开发 出 动态 网 页 。 


。 本 模块 的 任务 重点 。 








PHP 基础 程序 的 结构 

PHP 表单 变量 的 使 用 

PHP 程序 中 常量 、 变 量 、 表 达 式 以 及 函数 的 基础 
掌握 MySQL 数据 库 的 操作 
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二 1|_PHP 程序 的 基本 结构 


在 编写 动态 网 页 程序 时 ， 可 以 将 HTML 标记 与 动态 语言 的 代码 混合 到 一 个 文件 中 ， 通 
过 使 用 一 些 特殊 的 标识 ， 将 两 者 区 别 开 来 ， 例 如 ，ASP 使 用 的 是 <% %>。PHP 也 是 如 此 ， 
可 以 与 HTML 标记 共存 , PHP 提供 了 多 种 方式 来 与 HTML 标记 区 分 , 可 以 根据 自己 的 习惯 
选择 一 种 方式 ， 也 可 以 同时 使 用 几 种 方式 。 这 里 将 介绍 一 下 PHP 的 基础 程序 结构 ， 包 括 输 
出 和 注释 的 方法 。 


1.1 程序 的 基本 结构 


PHP 程序 的 结构 与 Perl 以 及 C 一 样 ， 结 构 比 较 严 谨 ， 需 要 在 每 条 语句 后 使 用 分 号 “;” 
来 作为 结束 。 此 外 ， 语 句 中 的 大 小 写 是 敏感 的 。 

在 HIML 文件 中 嵌入 PHP 脚本 的 常用 方式 有 以 下 3 种 。 

(1) PHP 标准 结构 (推荐 ): 


<?php 
echo "这 是 第 一 个 PHP 程序 !"; 


2 

(2) PHP 的 简短 风格 (需要 设置 php.ini): 

<? echo "这 是 第 一 个 PHP 程序 ! "; ?> 

(3) PHP 的 脚本 风格 (元 长 的 结构 ): 

<script language="php"> echo "这 是 第 一 个 PHP 程序 ! " ; </script> 

在 C:\Apache\htdocs\ 中 建立 一 个 php 文件 夹 ， 用 来 保存 本 节 的 实例 ， 保 存 为 pg001; 刚 
开始 创建 文档 时 都 用 记事 本 进行 编写 ， 保 存 为 “php” 文 件 即 可 。 运 行 结果 如 图 2-1 所 示 。 





马 无 标题 文档 - Hicrosoft Internet Explorer 攻 ] 古 |] 区 | 


文件 @) 编辑 EE) 查看 W) 收藏 W) 工具 C) 帮助 忆 
地 址 加) | 者 http:77127.0.0.17phpypaool. php 口 v 








这 是 第 一 个 PHP 程 序 ! 





图 2-1 输出 的 第 一 个 PHP 程序 


实际 开发 时 ， 最 常用 第 一 种 方法 和 第 二 种 方法 ， 即 ， 使 用 小 于 号 加 上 问号 “<?”， 或 
者 使 用 “<?php”， 之 后 跟 PHP 代码 ， 在 程序 代码 的 最 后 ， 使 用 问号 和 大 于 号 “?>” 作 为 结 
束 。 第 三 种 方法 有 点 类 似 于 JavaScript 的 编写 方式 。 
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1.2 打印 输出 结果 


PHP 输出 可 以 用 echo0 命 令 , echo0 是 一 个 语言 结构 , 不 一 定 要 使 用 小 括号 来 指明 参数 ， 
单 引 号 、 双 引号 都 可 以 。echo0 不 像 其 他 语言 结构 表现 得 像 一 个 函数 ， 所 以 不 能 总 是 使 用 一 
个 函数 的 上 下 文 。 另 外 ， 如 果 想 给 echo() 传 递 多 个 参数 ， 就 不 能 使 用 小 括号 。 
于 注意 ; ”也 可 以 使 用 print() 命 令 ， 但 echo0 比 print0 运 行 速度 快 一 些 。 


举例 使 用 PHP 输出 语句 ， 包 括 HTML 格式 化 标签 : 


<?php 
echo "<p> 这 是 我 输出 打印 的 第 一 个 文档 。<P>"; 


诉 三 对 咖 器 dHd | | 过 匡 


i 


输出 的 结果 如 图 2-2 所 示 。 


台 无 标题 文档 - Microsoft Internet Explorer 恬 | 顾 | 区 | 
文件 全 ”编辑 下 ) 查看) 收 豪 ) 工具 CD 玫 助 们 
地 址 轴 | 图 http://127.0.0. 1/php/pan02.php 





这 是 我 输出 打印 的 第 一 个 文档 。 





2-2 用 echo 输出 字符 串 


1.3 ”程序 的 注释 


在 PHP 程序 的 编写 过 程 中 ， 可 以 使 用 如 下 所 示 3 种 风格 的 注释 方式 : 


/* 第 1 种 PHP 注释 适合 用 于 多 行 */ 
// 第 2 种 PHP 注释 适用 于 单行 
# 第 3 种 PHP 注释 适用 于 单行 


注释 与 C、C++、Shell 的 注释 风格 一 样 ， 以 “/*” 为 开始 ，“*/” 为 结束 ， 如 下 所 示 : 


<?php 
/* 
注释 : 这 是 程序 的 注释 
该 程序 主要 用 于 文字 的 说 明 …… 
人 


区 


单行 注释 (有 // 和 # 这 两 种 ): 

<?php 
echo "单行 "; // 输 出 “单行 ”文字 
echo "说 明 "; # 输 出 “说 明 ” 文 字 


2 
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了 还 注意 : ”注释 符号 只 有 在 <?php ..…. ?> 里 才 会 获得 应 有 的 效果 ， 如 图 2-3 所 示 。 


外 pg003. php 一 记事 本 
文件 四 编辑 四， 格式 @) 查看 由 和 助 0 
<?php 





由 
注释 :这 是 程序 的 注释 
该 程序 主要 用 于 文字 的 说 明 


3> 


<?php 
echo "单行 // 输 出 单行 文字 
echo "说 明 "， 庆 疹 出 说 明文 字 


2> 








图 2-3 带 有 注释 的 程序 





国 ] :| 动态 输出 字符 


在 实际 的 网 页 设计 过 程 中 ， 单 单 使 用 echo0 函 数 命令 并 不 能 满足 需求 ， 例 如 ， 要 输出 随 
机 数 ， 控 制 字符 串 的 大 小 写 ， 以 及 一 些 特殊 的 字符 处 理 等 常用 操作 ， 都 可 以 通过 调用 相应 
的 函数 命令 加 以 实现 。 


2.1 随机 函数 的 调用 


如 果 要 实现 相应 的 字符 控制 ， 就 需要 调用 相应 的 函数 命令 ， 在 PHP 编程 中 ， 调 用 相应 
的 函数 还 是 比较 简单 的 ， 如 使 用 rand0 函 数 产生 一 个 随机 数 (范围 是 0-10): 

<?php 

echo rand(0, 10); 

> 

刷新 页 面 ， 便 可 以 看 到 输出 结果 的 变化 ，rand() 函 数 中 的 0 和 10 为 指定 给 rand 函数 的 
参数 。 前 面 的 0 意味 着 最 小 可 能 出 现 的 数值 为 0， 后 面 的 10 意味 着 最 大 可 能 出 现 的 数值 为 
10， 很 多 函数 都 有 必 选 或 者 可 选 的 参数 。 如 图 2-4 所 示 ， 随 机 输出 的 数 为 6。 








可 无 标题 文档 - Hicrosoft Internet Explorer 攻占 |] 攻 | 
文件 EC) 编辑 E) 查看 WD 收 若 Q) 工具 CD) 帮助 0 霹 
地 址 中) | 逢 http://127.0.0.1/php/peD04.php Ov 
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图 2-4 随机 函数 的 输出 
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2.2 ”对 字符 串 首尾 空格 的 控制 
使 用 tim0 函 数 可 以 返回 去 除 字符 串 string 首尾 空白 字符 后 的 字符 串 。 语 法 如 下 : 


String trim(string str); 


返回 值 : 字符 串 。 
函数 种 类 : 数据 处 理 。 
在 使 用 来 自 HTML 表单 的 信息 之 前 ， 一 般 都 会 对 这 些 数 据 做 一 些 整理 ， 举 例如 下 : 


<?php 
// 清 理 字符 串 中 开始 和 结束 位 置 的 多 余 空格 
Sname = " 12345678 "™; 


$name = trim($name); 
echo $name; 
Fi 


运行 的 结果 可 以 将 前 后 的 空白 去 除 ， 如 图 2-5 所 示 。 


名 无 标题 文档 - Hicrosoft Internet Explorer 导 | 右 | 区 | 
文件 @) 编辑 E) 查看 WW) 收藏 和 ) 工具) 帮助 忌 
地 址 四) 四 http:/7127.0.0. 1/phpypz005.php Ox 





12345678 





图 2-5 去 除 前 后 空白 的 输出 效果 


2.3 ”字符 串 的 格式 化 输出 
nl2br0 函 数 可 以 将 字符 串 中 的 换行 转换 成 HTML 换行 的 <br> 指 令 。 语 法 如 下 : 


String nl2br (string string); 
返回 值 : 字符 串 。 

函数 种 类 : 数据 处 理 。 

举例 如 下 : 

<?php 

$str = " 今天 是 周一 ， 心 情 也 很 好 。 
决定 去 学 校 游泳 场 ， 好 好 的 游 个 泳 。"; 
echo $str; 

echo "<br /> 


echo nl2br ($str); 
Ea 


诉 三 对 咖 器 dHd | | 车 需 
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输出 的 结果 如 图 2-6 所 示 。 
久 无 标题 文档 - Microsoft Internet Explorer 攻占 |] 必 ] 


文件 下 ”编辑 EE) 查看 W) 收 训 和 ) 工具 中 帮助 胃 | 订 
地 址 名 | 莉 http://127.0.0. 1/php/peD06. php Ov 











今天 是 周一 ， 心 情 也 很 好 。 决 定 去 学 校 游泳 场 ,好 好 “。 
的 落 个 汶 


今天 是 周一 ， 心 情 也 很 好 
决定 去 学 校 游泳 场 ， 好 好 的 游 个 汶 





2-6 ”格式 化 输出 字符 的 结果 


2.4 格式 化 输出 


PHP 除了 支持 echo 功能 而 外 ， 也 可 以 使 用 printt0)， 来 实现 更 复杂 的 格式 化 输出 。 
语法 如 下 : 


int printf (string format, mixed [args]...); 


返回 值 ， 整 数 。 
函数 种 类 : 数据 处 理 。 
举例 如 下 : 


<?php 
$num = 3.6; 
// 将 $num 里 的 数值 以 字符 串 的 形式 输出 
printf ("数值 为 :$s"， $num); 
echo "<br />"; 
// 转换 成 为 带 有 2 位 小 数 的 浮 点 数 
printf ("数值 为 :$ .2f"， $num); 
echo "<br />"; 
// 解释 为 整数 并 作为 二 进 制 数 输出 
printf ("数值 为 :$b"， $num); 
echo "<br />"; 
// 打印 $ 符 号 
printf ("数值 为 :$%%s"， $num); 
Ss 


输出 的 结果 如 图 2-7 所 示 。 


Hicrosoft Internet Ezplorer 尾 | 器 | 区 | 


文件 中 编辑) 查看 W) 收 训 和) 工具 DJ 帮助 加 知 
地 址 加) | 撞 http: /1127.0.0. 1/php/peD07. php Ov 








图 2-7 格式 化 输出 的 效果 
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2.5 ”字母 的 大 小 写 转 换 


字母 的 大 小 写 转换 在 PHP 网 页 中 经 常 使 用 到 ， 涉 及 的 常用 函数 如 下 。 


@ strtoupper(): 将 字符 串 转 换 成 大 写字 母 。 
@ ”ucwords(): 将 每 个 单词 的 第 一 个 字母 变 成 大 写 。 
@ ucfirst0: 将 字符 串 的 第 一 个 字母 转 成 大 写 。 
@ “strtolower(): 将 字符 串 转 换 成 小 写字 母 。 
举例 如 下 : 
<?php 

$str = "I like php!"; 

// 将 字符 串 转 换 成 大 写字 母 

echo strtoupper ($str)."<br />"; 

// 将 字符 串 转 换 成 小 写字 母 

echo Strtolower ($str) ."<br />"; 

// 将 字符 串 的 第 一 个 字母 转换 成 大 写 

echo ucfirst(Sstr) <bE />"» 

// 将 每 个 单词 的 第 一 个 字母 转换 成 大 写 

echo ucwords ($str)."<br />"; 
?> 
输出 的 结果 如 图 2-8 所 示 。 


下 无 标题 文档 - Microsoft Internet Explorer 
文件 G) 编辑 里 ) 查看 WD 收 世人) 工具 DD) 帮助 0D 


地 址 四) | 御 http://127.0.0.1/php/pz008.php 





ILIKE PHP! 


ILike Phpl 


2-8 ”字母 转换 大 小 写 


2.6 ”特殊 字符 的 处 理 
有 些 字符 对 于 MySQL 是 有 特殊 意义 的 ， 比 如 引号 、 反 斜 杠 和 NULL 字符 。 可 以 使 用 


addslashes() 函 数 和 stripslashes() 函 数 正确 处 理 这 些 字符 ， 例 如 : 


<?php 


Bs 


$str 
echo 
echo 
echo 


= w\n NNOLL". 
St Dr /on 

addslashes ($str) ."<br />"; 
stripslashes ($str)."<br />"; 


运行 结果 如 图 2-9 所 示 。 





诉 三 对 咖 器 dHd | | 过 匡 
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文件 四 ” 编 铝 下 查看 加 收 戌 和) I 具 Q) 帮助 WD 讲 
起 址 加) | 痢 http://127.0.0.1/php/peD09 php Dv 





~ 


”NULL 
VNWNULL 
”NULL 





2-9 ”处 理 特殊 的 字符 串 





3 | 表单 变量 的 应 用 


在 HIML 中 ， 表 单 拥有 一 个 特殊 功能 : 支持 交互 操作 。 

除了 表单 之 外 ， 几 乎 所 有 的 HTML 元 素 都 与 设计 以 及 展示 有 关 ， 只 要 愿意 ， 就 可 将 内 
容 抄 送 给 用 户 ， 另 一 方面 ， 表 单 为 用 户 提供 了 将 信息 传送 回 Web 站 点 创建 者 和 管理 者 的 可 
能 性 。 如 果 没 有 表单 ，Web 就 是 一 个 静态 的 网 页 。 对 于 PHP 动态 网 页 开发 来 说 ， 使 用 表单 
变量 是 经 常 遇 到 的 ， 通 常 主要 有 POST 和 GET 两 种 方法 ， 这 与 其 他 动态 语言 开发 的 命令 是 
一 样 的 ， 这 里 将 介绍 表单 变量 的 使 用 方法 。 


3.1 POST 表单 变量 


POST 用 于 设置 处 理 表单 数据 的 类 型 ，POST 是 系统 的 默认 值 ， 表 示 将 数据 表单 的 数据 
提交 到 “动作 ”属性 设置 的 文件 中 进行 处 理 。 假 设 有 一 个 HTML 表单 用 method=“post” 的 方 
式 传递 本 页 name='“'test" 输 入 框 中 输入 的 文字 信息 ， 可 用 3 种 风格 来 显示 这 个 表单 变量 : 


<form action=" " method="post"> 

<input type="text" name="test" /> 

<input type="submit" name=" 变 量 "” value=" 提 交 " /> 

<?php 
echo $test; // 简 短 格式 ， 需 要 配置 php.ini 中 的 默认 值 
echo $ POST["test"]; // 中 等 格式 ， 推 荐 使 用 这 种 方式 
echo $HTTP POST VARS["test"]; // 宛 长 格式 








运行 结果 如 图 2-10 所 示 。 


文件 四 编辑 人) 查看 W) 收 豪 W) 工具 QD) 帮助 0 
地 址 加 | 御 http://127.0.0. 1/php/pan10.php 








] 区 芝 ] 传递 变量 





图 2-10 POST 测试 的 效果 
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3.2 GET 表单 变量 


GET 表示 追加 表单 的 值 到 URL 并 且 发 送 服务 器 请 求 ， 对 于 数据 量 比较 大 的 长 表单 ， 最 
好 不 要 用 这 种 数据 处 理 方式 。 

假设 有 一 个 HTML 表单 用 method=“get” 的 方式 传递 本 页 一 个 name=“test" 输 入 框 中 输入 
的 文字 信息 ， 可 用 3 种 风格 来 显示 这 个 表单 变量 : 


<form action=" " method="get"> 

<input type="text" name="test" /> 

<input type="submit" name=" 变 量 " value=" 提 交 " /> 

<?php 
echo S$test; // 简 短 格式 ， 需 要 配置 php . ini 中 的 默认 值 
echo $ GET["test"];  ”// 中 等 格式 ,推荐 使 用 这 种 方式 
echo $HTTP GET VARS["test"];  ”// 匈 长 格式 


诉 三 对 了 归 器 dHd | | 颈 需 
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</form> 


运行 结果 如 图 2-11 所 示 。 


包 无 标题 文档 - Hicrosoft Internet Explorer 基因 | 区 | 
文件 E) 编辑 FE) 查看 WW) 收 京 4) 工具 C) 帮助 亡 
地 址 0) | 护 http://127.0.0. 1/php/peDll. php?test=123456 口 





攻 国 23456 





2-11 GET 测试 效果 


GET 和 了 POST 的 主要 区 别 如 下 : 

@ ”数据 传递 的 方式 以 及 大 小 。 

®@ ”GET 会 将 传递 的 数据 显示 在 URL 地 址 上 ，POST 则 不 会 。 
@ ”GET 传递 数据 有 限制 ， 一 般 大 量 数据 都 得 使 用 POST 方法 。 


3.3 ”连接 字符 串 


在 PHP 程序 里 ， 对 多 个 字符 串 进行 连接 时 ， 要 用 到 一 个 点 号 “.”， 如 下 所 示 : 
<2php 

Swebsite = "www.tj1j"; 

echo S$website . ".tj.com"; 
Re 


上 面 的 输出 结果 就 是 “www.tjlj.tj.com”， 如 图 2-12 所 示 。 
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下 无 标题 文档 - Hicrosoft Internet Explorer 车 | 占 | 区 | 
文件 @) ”编辑 下 ) 查看 0 收藏) 工具 如 帮助 00 EE 
地 址 中 | 御 http://127.0.0. 1/php/peD12. php 口 v| 








www.tjij tj.com 





图 2-12 ”连接 字符 串 输 出 的 结果 
有 一 种 情况 ， 当 echo 后 面 使 用 的 是 双 引 号 时 ， 可 以 这 样 来 取得 与 上 面 同样 的 效果 : 


<?php 
$website = "www.tjl1j"; 
echo "$website..tj.com"; 
// 双 引号 里 的 变量 还 是 可 以 显示 出 来 ， 并 与 一 般 的 字符 串 自动 区 分 开 来 


和 


但 如 果 是 单 引 号 的 话 ， 就 会 将 里 面 的 内 容 完全 以 字符 串 形式 输出 给 浏览 器 : 
<?php 

Swebsite = "www.tjlj"; 

echo '$website..tj.com'; 
?> 


将 显示 “ $website..tj.com”。 








4 | PHP 常量 和 变量 


常量 和 变量 是 编程 语言 的 最 基本 构成 ， 代 表 了 运算 中 所 需 的 各 种 值 。 通 过 变量 和 常量 ， 
程序 才能 对 各 种 数值 进行 访问 和 运算 。 

学 习 变 量 和 常量 是 编程 的 基础 。 常 量 和 变量 的 功能 就 是 用 来 存储 数据 的 ， 但 区 别 在 于 ， 
常量 一 旦 初始 化 就 不 再 发 生变 化 ， 可 以 理解 为 符号 化 的 常数 。 


4.1 PHP 中 的 常量 





常量 是 指 在 程序 执行 过 程 中 无 法 修改 的 值 。 在 程序 中 处 理 不 需要 修改 的 值 时 ， 常 量 非 
常 有 用 ， 例 如 定义 圆周 率 PI。 常 量 一 旦 定义 ， 在 程序 的 任何 地 方 都 不 可 以 修改 ， 但 可 以 在 
程序 的 任何 地 方 访问 。 

在 PHP 中 ,使 用 defineO) 函 数 来 定义 常量 ， 函 数 的 第 1 个 参数 表示 常量 名 ,第 2 个 参数 
表示 常量 的 值 。 

例如 ， 下 面 定义 一 个 名 为 HOST 的 常量 : 


<?php 
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define ("HOST", "www-t]jlj .tj -cn") > 
echo HOST7 
> 


运行 结果 如 图 2-13 所 示 。 


要 无 标题 文档 - Hicrosoft Internet Explorer 丑 ] 下 区] 
文件 编辑 E) 查看 0 收 荐 和 工具 上 ”帮助 怖 
地 址 四) | 逢 http://127.0.0. 1/php/peD13. php 品名 


话 辆 告 磺 吕 dHd | | 绒 需 





wwwt 刘 -cn 





2-13 ”定义 常量 后 的 输出 结果 


痊 注意 : ”常量 默认 区 分 大 小 写 ， 按 照 惯例 ， 常 量 标识 符 总 是 大 写 。 常 量 名 和 其 他 任何 
PHP 标记 遵循 相同 的 命名 规则 。 合 法 的 常量 名 以 字母 或 下 划 线 开始 ， 后 面 跟 
任何 字母 、 数 字 或 下 划 线 。 

PHP 的 系统 常量 包括 5 个 魔术 常量 和 大 量 的 预定 义 常量 。 
魔术 常量 会 根据 它们 使 用 的 位 置 而 改变 ，PHP 提供 的 5 个 魔术 常量 分 别 如 下 。 
e@  _LINE_: 表示 文件 中 的 当前 行 号 。 
e@  _FILE_: 表示 文件 的 完整 的 路 径 和 文件 名 。 如 果 用 在 包含 文件 中 ， 则 返回 包含 文 
件 名 。 自 PHP 4.0.2 起 ， FILE 总 是 包含 一 个 绝对 路 径 (如果 是 符号 连接 ， 则 是 解 
析 后 的 绝对 路 径 )， 而 在 此 之 前 的 版 本 有 时 会 包含 一 个 相对 路 径 。 
e@ _FUNCTION_: 表示 函数 名 称 (PHP 4.3.0 新 加 )。 自 PHP 5 起 ， 本 常量 返回 该 函数 
被 定义 时 的 名 字 ( 区 分 大 小 写 )。 在 PHP 4 中 ， 该 值 总 是 小 写字 母 的 。 
@ _CLASS_: 表示 类 的 名 称 (PHP 4.3.0 新 加 )。 自 PHP 5 起 ， 本 常量 返回 该 函数 被 定 
义 时 的 名 字 ( 区 分 大 小 写 )。 在 PHP 4 中 ， 该 值 总 是 小 写字 母 的 。 
e。 _METHOD_: 表示 类 的 方法 名 (PHP 5.0.0 新 加 )。 返回 该 方法 被 定义 时 的 名 字 ( 区 分 
大 小 写 )。 
预定 义 常量 又 分 为 内 核 预 定义 常量 和 标准 预定 义 常量 两 种 ， 内 核 预 定义 常量 在 PHP 
的 内 核 、Zend 引擎 和 SAPI 模块 中 定义 ， 而 标准 预定 义 常量 是 PHP 默认 定义 的 。 比 如 常用 
的 E ERROR、E_NOTICE、E _ALL 等 。 


4.2 ”PHP 中 的 变量 





在 PHP 中 , 创建 一 个 变量 时 , 首先 需要 定义 变量 的 名 称 。 变量 名 区 分 大 小 写 , 总 是 以 $ 符 
号 开头 ， 然 后 是 变量 名 。 如 果 在 声明 变量 时 ， 忘 记 变量 前 面 的 $ 符 号， 那么 该 变量 将 无 效 。 
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在 PHP 中 设置 变量 的 正确 方法 如 下 : 


$var name = value; 


在 PHP 中 ， 可 以 使 用 值 赋值 和 引用 赋值 两 种 方法 为 变量 赋值 。 
值 赋值 是 直接 把 一 个 数值 通过 赋值 表达 式 传递 给 变量 。 值 赋值 是 一 种 常用 的 变量 赋值 


的 方法 ， 其 使 用 格式 举例 说 明 如 下 : 


<?php 

$name = "baidu"; // 有 效 变 量 

SName = "website"; // 有 效 变 量 

echo "$name, $Name"; // 输 出 为 “baidu， website” 
$lwebsite = "www.baidu.com"; // 无 效 变量 ， 以 数字 开头 

$ lwebsite = "www.baidu.com"; // 有 效 变量 
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从 上 述 代码 中 可 以 看 到 ， 在 PHP 中 ， 不 需要 在 设置 变量 之 前 声明 该 变量 的 类 型 ， 而 是 


根据 变量 被 设置 的 方式 ，PHP 会 自动 把 变量 转换 为 正确 的 数据 类 型 。 


在 PHP 中， 变量 的 命名 规则 有 如 下 几 点 : 

e@ ”变量 名 必须 以 字母 或 下 划 线 开头 。 

e@ ”变量 名 只 能 包含 字母 、 数 字 、 字 符 以 及 下 划 线 。 

e@ ”变量 名 不 能 包含 空格 。 如 果 变 量 名 由 多 个 单词 组 成 ， 那 么 应 该 使 用 下 划 线 分 隔 ( 例 
如 $my _string)， 或 者 以 大 写字 母 分 隔 (例如 SmyString)。 

在 PHP 中 ， 还 支持 另 一 种 赋值 方式 ， 称 为 变量 的 引用 赋值 ， 例 如 : 


<?php 
$wo = 'baigu'; // 为 变量 $wo 赋值 
$ba = &S$wo; // 变 量 Sba 引用 了 变量 $wo 的 值 
Sba = "Web site is $ba™; // 修 改变 量 $ba 的 值 
echo S$wo; // 结 果 为 “Web site is $ba” 
echo $ba; // 结 果 为 “Web site is $ba” 
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从 这 里 可 以 看 出 ， 对 一 个 变量 值 的 修改 将 会 导致 另 一 个 变量 值 的 修改 。 从 本 质 上 讲 ， 


变量 的 引用 赋值 导致 两 个 变量 的 值 指向 同一 个 内 存 地 址 。 因 此 ， 不 论 对 哪 一 个 变量 进行 修 
改 ， 修 改 的 都 是 同一 个 内 存 地 址 中 的 数据 ， 从 而 出 现 同时 被 修改 的 结果 。 











PHP 提供 了 大 量 的 预定 义 变量 ， 这 些 变量 在 任何 范围 内 都 会 自动 生效 ， 因 此 ， 通 常 也 








被 称 为 自动 全 局 变量 (Auto Globals) 或 者 超 全 局 变量 (Super Globals，PHP 中 没有 用 户 自 定义 
超 全 局 变量 的 机 制 )。 在 PHP 4.1.0 之 前 ,如 使 用 超 全 局 变量 ， 人 们 要 么 依赖 register_globals， 
要 么 就 是 长 长 的 预定 义 PHP 数组 (SHTTP * VARS)。 自 PHP 4.1.0 起 ， 长 格式 的 PHP 预定 
义 变量 可 以 通过 设置 register long arrays 来 屏蔽 。 
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常用 的 超 全 局 变量 如 下 。 


SGLOBALS: 包含 一 个 引用 ， 指 向 每 个 当前 脚本 的 全 局 范围 内 有 效 的 变量 。 该 数 
组 的 键 名 为 全 局 变量 的 名 称 。 从 PHP 3 开始 就 存在 SGLOBALS 数组 。 
$SSERVER: 变量 由 Web 服务 器 设 定 ， 或 者 直接 与 当前 脚本 的 执行 环境 关联 。 类 
似 于 旧 数组 SHTTP_SERVER_VARS( 依 然 有 效 ， 但 反对 使 用 )。 

$_GET: 经 由 URL 请 求 提交 至 脚本 的 变量 。 类 似 于 旧 数 组 SHTTP_GET_VARS( 依 
然 有 效 ， 但 反对 使 用 )。 

$_POST: 经 由 HTTP POST 方法 提交 至 脚本 的 变量 。 类 似 于 旧 数 组 SHTTP POST 
VARS( 依 然 有 效 ， 但 反对 使 用 )。 

$_COOKIE: 经 由 HITP Cookies 方法 提交 至 脚本 的 变量 。 类 似 于 旧 数组 SHTTP 
COOKIE VARS( 依 然 有 效 ， 但 反对 使 用 )。 

$_FILES: 经 由 HTTP POST 文件 上 传 而 提交 至 脚本 的 变量 。 类 似 于 旧 数 组 
S$SHTTP POST _ FILES( 依 然 有 效 ， 但 反对 使 用 )。 

$_ENV: 执行 环境 提交 至 脚本 的 变量 。 类 似 于 旧 数 组 SHTTP_ENV_VARS( 依 然 有 
效 ， 但 反对 使 用 )。 

$_REQUEST: 经 由 GET、POST 和 Cookie 机 制 提交 至 脚本 的 变量 ， 因 此 该 数组 
并 不 值得 信任 。 所 有 包含 在 该 数组 中 的 变量 存在 与 否 以 及 变量 的 顺序 均 按照 
php.ini 中 的 variables_order 配置 指示 来 定义 。 此 数组 在 PHP 4.1.0 之 前 没有 直接 对 
应 的 版 本 。 

$_SESSION: 当前 注册 给 脚本 会 话 的 变量 。 类 似 于 旧 数 组 SHTTP SESSION _ 
VARS( 依 然 有 效 ， 但 反对 使 用 )。 


4.3 PHP 数据 类 型 


数据 是 程序 运行 的 基础 ， 所 有 的 程序 都 是 在 处 理 各 种 数据 。 例 如 ， 财 务 统计 系统 所 要 
处 理 的 员工 工资 额 ， 论 坛 程序 所 要 处 理 的 用 户 名 、 密 码 、 用 户 发 帖 数 等 ， 所 有 这 些 都 是 数 
据 。 在 编程 语言 中 ， 为 了 方便 对 数据 的 处 理 以 及 节省 有 限 的 内 存 资源 ， 需 要 对 数据 进行 分 
类 。PHP 支持 下 列 7 种 原始 类 型 。 





boolean: 布尔 型 true/false。 
integer: 整数 类 型 。 

float: 浮 点 类 型 。 

string: 字符 串 类 型 。 
array: 数组 。 
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@ object: 对 象 。 
@ ”特殊 类 型 : resource 资源 和 NULL。 
下 面 介绍 常用 的 数据 类 型 。 
1. 布尔 型 boolean 


布尔 型 是 最 简单 的 类 型 ， 它 表达 了 真 值 ， 可 以 为 True 或 False。 要 指定 一 个 布尔 值 ， 使 


用 关键 字 True 或 False， 并 且 True 或 False 不 区 分 大 小 写 。 


例如 : 
$pay = true; // 给 变量 $pay 赋值 为 true 


某 些 运算 通常 返回 布尔 值 ， 并 将 其 传递 给 控制 流程 。 比 如 用 比较 运算 符 (一 ) 来 比较 两 个 


运算 数 ， 如 果 相 等 ， 则 返回 True， 和 否则 返回 False。 代 码 如 下 : 


if ($A == $B) { 
echo "$A 与 $B 相等 "; 
} 


对 于 如 下 代码 : 


if ($pay == TRUE) { 
echo "已 付 "; 


可 以 使 用 下 面 的 代码 代替 : 


if ($pay) { 
echo "已 付 "; 
} 


转换 成 布尔 型 用 bool 或 boolean 来 强制 转换 ， 但 是 ， 很 多 情况 下 不 需要 用 强制 转换 ， 


因为 当 运算 符 、 函 数 或 者 流程 控制 需要 一 个 布尔 参数 时 ， 该 值 会 被 自动 转换 。 


当 转 换 为 布尔 型 时 ， 以 下 值 被 认为 是 False: 
布尔 值 False。 

整 型 值 0( 零 )。 

浮 点 型 值 0.0( 零 )。 

空白 字符 串 和 字符 串 “0”。 

没有 成 员 变量 的 数组 。 

没有 单元 的 对 象 ( 仅 适 用 于 PHP 4)。 
特殊 类 型 NULL( 包 括 尚未 设 定 的 变量 )。 
所 有 其 他 值 都 被 认为 是 True( 包 括 任何 资源 )。 


2. 整 型 integer 


一 个 整数 是 集合 Z2={..…, -2, -1, 0, 1, 2, .…} 中 的 一 个 数 。 整 型 值 可 以 用 十 进 制 、 十 六 进 制 
或 八进制 表示 ， 前 面 可 以 加 上 可 选 的 符号 (- 或 +)。 如 果 用 八进制 ， 数 值 前 必须 加 上 0( 零 )， 
用 十 六 进 制 数 时 前 面 必须 加 上 0x。PHP 不 支持 无 符号 整数 。 整 数 的 字 长 与 平台 有 关 ， 通 常 
最 大 值 大 约 是 二 十 亿 (32 位 有 符号 数 )。 如 果 给 定 的 一 个 数 超出 了 整数 的 范围 , 将 会 被 解释 为 
浮 点 型 ， 同 样 ， 执 行 的 运算 结果 超出 了 整数 的 范围 时 ， 也 会 返回 浮 点 型 。 

要 将 一 个 值 转换 为 整 型 , 可 用 int 或 integer 强制 转换 。 不 过 大 多 数 情况 下 都 不 需要 强制 
转换 ， 因 为 当 运算 符 、 函 数 或 流程 控制 需要 一 个 整 型 参数 时 ， 值 会 自动 转换 。 还 可 以 通过 
函数 intval() 来 将 一 个 值 转换 成 整 型 。 

从 布尔 型 转换 成 整 型 ，False 将 产生 出 0，True 将 产生 出 1。 当 从 浮 点 型 转换 成 整 型 时 ， 
数字 将 被 取 整 (丢弃 小 数位 )。 如 果 浮 点 数 超出 了 整数 范围 ， 则 结果 不 确定 ， 因 为 没有 足够 的 
精度 使 浮 点 数 给 出 一 个 确切 的 整数 结果 。 

3. 浮 点 型 float 


浮 点 数 也 叫 双 精 度数 或 实数 ， 可 以 用 以 下 任何 语法 来 定义 : 


<?php 
$a = 1.234; 
$b = 1.2e3; 
$c = 7E-10; 
2> 


浮 点 数 的 字 长 与 平台 有 关 ， 通 常 ， 最 大 值 是 1.8e+308 并 具有 14 位 十 进 制 数 的 精度 。 
4. 字符 串 string 
字符 串 是 由 引号 括 起 来 的 一 些 字符 ， 常 用 来 表示 文件 名 、 显 示 信 息 、 输 入 提示 符 等 。 


字符 串 是 一 系列 字符 ， 字 符 串 的 大 小 没有 限制 。 字 符 串 可 以 用 单 引 号 、 双 引号 或 定 界 符 三 
种 方法 定义 ， 下 面 分 别 介绍 这 三 种 方法 。 
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(1) 单 引号 
指定 一 个 简单 字符 串 的 最 简单 的 方法 是 用 单 引 号 括 起 来 。 
例如 : 
<?php 
echo "Hello Word'; // 输出 为 : Hello Word 


Bs 


如 果 字 符 串 中 有 单 引 号 ， 要 表示 这 样 一 个 单 引 号 ， 与 很 多 其 他 语言 一 样 ， 需 要 用 反 斜 
线 () 转 义 。 例 如 : 
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<?php 
echo 'IN'm Tom'; // 输出 为 : I'm Tom 
> 


如 果 在 单 引 号 之 前 或 字符 串 结尾 需要 出 现 一 个 反 斜 线 ()， 需 要 用 两 个 反 斜 线 (\) 表 示 。 
例如 : 


<?php 
echo 'Path is c:\windows\system\\'; 
// 输出 为 : Path is c:\windows\system\ 
2 


对 于 单 引号 括 起 来 的 字符 串 ，PHP 只 懂得 单 引号 和 反 斜 线 的 转 义 序列 。 如 果 试 图 转 义 
任何 其 他 字符 ， 反 斜 线 本 身 也 会 被 显示 出 来 。 另 外 ， 不 同 于 双 引 号 和 定 界 符 的 很 重要 的 一 
点 就 是 ， 单 引号 字符 串 中 出 现 的 变量 不 会 被 解析 。 


(2) 双 引 号 
如 果 用 双 引 号 括 起 字符 串 ，PHP 懂得 更 多 特殊 字符 的 转 义 序列 ( 见 表 2-1)。 
表 2-1 转 义 字符 
序 列 含义 

n 换行 
YY 回 车 
At 水 平 制 表 符 
\ 反 斜 杠 字符 
\$ 美元 符号 
iy 双 引 号 
\Onnn 此 正则 表达 式 序列 匹配 一 个 用 八进制 表示 的 字符 
\xnn 此 正则 表达 式 序列 匹配 一 个 用 十 六 进 制 表示 的 字符 





如 果 试 图 转 义 任何 其 他 字符 ， 反 斜 线 本 身 同样 也 会 被 显示 出 来 。 双 引号 字符 串 最 重要 
的 一 点 是 能 够 解析 其 中 的 变量 。 

(3) 定 界 符 

另 一 种 给 字符 串 定 界 的 方法 就 是 使 用 定 界 符 语法 (<<<)。 应 该 在 <<< 之 后 提供 一 个 标识 
符 ， 接 着 是 字符 串 ， 然 后 是 同样 的 标识 符 结束 字符 串 。 例 如 : 


<?php 
// 输出 为 : Hello World 
echo <<<abc 
Hello World 
abc; 


在 此 段 代码 中 ， 标 识 符 命名 为 abc。 结 束 标 识 符 必须 从 行 的 第 一 列 开 始 。 标 识 符 所 遵循 
的 命名 规则 是 : 只 能 包含 字母 、 数 字 和 下 划 线 ， 而 且 必须 以 下 划 线 或 数字 字符 开始 。 

定 界 符 文 本 表现 得 就 与 双 引 号 字符 串 一 样 ， 只 是 没有 双 引 号 。 这 意味 着 在 定 界 符 文 本 
中 不 需要 转 义 引 号 ， 不 过 ， 仍 然 可 以 用 以 上 列 出 的 转 义 代码 ， 变 量 也 会 被 解析 。 在 以 上 的 
三 种 定义 字符 串 的 方法 中 ， 若 使 用 双 引 号 或 者 定 界 符 定义 字符 串 ， 其 中 的 变量 会 被 解析 。 

5. 数组 array 


PHP 中 的 数组 实际 上 是 一 个 有 序 图 ， 图 是 一 种 把 value 映射 到 key 的 类 型 。 新 建 一 个 数 
组 ， 使 用 array0 语 言 结构 ， 它 接受 一 定数 量 用 逗号 分 隔 的 key=>value 参数 对 。 
语法 如 下 : 


array ([key =>] value, ...) 


其 中 , 键 key 可 以 是 整 型 或 者 字符 串 , 值 value 可 以 是 任何 类 型 , 如 果 值 又 是 一 个 数组 ， 
则 可 以 形成 多 维 数组 的 数据 结构 。 例 如 : 
<?php 
$edName = array (0=>"id", 1=>"username", 2=>"password"); 
echo " 列 名 是 SedName [0]，, $edName [1], $edName [2]"; 
?> 


此 段 代 码 的 输出 为 : 列 名 是 id,username,password。 
如 果 省 略 了 键 key， 会 自动 产生 从 0 开始 的 整数 索引 。 上 面 的 代码 可 以 改写 为 : 


<?php 
$edName = array ("id", "username", "password"); 
echo " 列 名 是 $edName [0] ,SedName [1], $edName [2]"; 
?> 
此 段 代 码 的 输出 仍 为 : 列 名 是 id.usermame.password。 
如 果 key 是 整数 ， 则 下 一 个 产生 的 key 将 是 目前 最 大 的 整数 索引 加 1。 如 果 指 定 的 键 已 
经 有 了 值 ， 则 新 值 会 覆盖 旧 值 。 再 次 改写 上 面 的 代码 : 


<?php 
$edName = array (l=>"id", "username", "password"); 
echo " 列 名 是 SedName [1] ,SedName [2], $edName [3]"; 
2 
此 段 代码 的 输出 仍 为 : 列 名 是 id,usemame,password。 
定义 数组 的 另 一 种 方法 是 使 用 方 括号 的 语法 ， 通 过 在 方 括号 内 指定 键 为 数组 赋值 来 实 
现 。 也 可 以 省 略 键 ， 在 这 种 情况 下 ， 给 变量 名 加 上 一 对 空 的 方 括号 []。 语 法 如 下 : 


$arrayName [key] = value; 
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$arrayName[] = value; 
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其 中 ， 键 key 可 以 是 整 型 或 者 字符 串 ， 值 value 可 以 是 任何 类 型 。 例 如 : 


<?php 
$edName [0] 
$edName [1] "username"™; 
$edName [2] "password"; 
echo " 列 名 是 SedName [0] ,SedName [1], $edName [2]"; 
?> 


此 段 代码 的 输出 仍 为 : 列 名 是 id.usemame.password。 

如 果 给 出 方 括号 但 没有 指定 键 ， 则 取 当 前 最 大 整数 索引 值 ， 新 的 键 将 是 该 值 加 1。 如 果 
当前 还 没有 整数 索引 ， 则 键 值 为 0。 如 果 指 定 的 键 已 经 有 值 了 ， 该 值 将 被 覆盖 。 

对 于 任何 的 类 型 一 一 布尔 、 整 型 、 浮 点 、 字 符 串 和 资源 ， 如 果 将 一 个 值 转换 为 数组 ， 
将 得 到 一 个 仅 有 一 个 元 素 的 数组 (其 下 标 为 0)， 该 元 素 即 为 此 标量 的 值 。 如 果 将 一 个 对 象 转 
换 成 数组 ， 所 得 到 的 数组 的 元 素 为 该 对 象 的 属性 (成 员 变量 )， 其 键 为 成 员 变 量 名 。 如 果 将 一 
个 NULL 值 转换 成 数组 ， 将 得 到 一 个 空 数 组 。 

6. 对 象 object 


使 用 class 定义 一 个 类 ， 然 后 使 用 new 类 名 (构造 函数 参数 ) 来 初始 化 类 的 对 象 。 该 数据 
类 型 将 在 后 面 的 实例 中 具体 应 用 并 进行 解析 。 
7. 其 他 数据 类 型 


除了 以 上 介绍 的 6 种 数据 类 型 ， 还 有 资源 和 NULL 两 种 特殊 类 型 。 下 面 简单 介绍 一 下 
资源 和 NULL 两 种 特殊 类 型 。 

(1) 资源 

资源 是 通过 专门 的 函数 来 建立 和 使 用 的 特殊 类 型 ， 保 存 了 外 部 资源 的 引用 。 可 以 保存 
打开 文件 、 数 据 库 连 接 、 图 形 画 布 区 域 等 的 特殊 句柄 ， 无 法 将 其 他 类 型 的 值 转换 为 资源 。 
资源 大 部 分 可 以 被 系统 自动 回收 。 

(2) NULL 

NULL 类 型 只 有 一 个 值 ， 就 是 区 分 大 小 写 的 关键 字 NULL。 特 殊 的 NULL 值 表示 变量 
没有 值 。 

在 下 列 情况 下 ， 一 个 变量 被 认为 是 NULL: 

e ”被 赋值 为 NULL。 

@ ”尚未 被 赋值 。 

e ”被 unset0( 释 放 给 定 的 变量 )。 

例如 : 


<?php 


ER 


Le 





$php = ""7 
if(isset ($a)) 

echo "[1] is NULL <br>"; 
$php = 0; 
if(isset ($a)) 

echo "[2] is NULL<br>"; 
$php = NULL; 
if (isset ($a)) 

echo "[3] is NULL<br>"; 
$php = FALSE; 
if (isset ($a)) 

echo "[4] is NULL<br>"; 
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> 


读者 考虑 一 下 ， 结 果 是 什么 ? 
4.4 数据 类 型 转换 


在 PHP 中 ， 若 要 进行 数据 类 型 的 转换 ， 就 要 在 转换 的 变量 之 前 加 上 用 括号 括 起 来 的 目 
标 类 型 。 在 变量 定义 中 不 需要 显示 的 类 型 定义 是 根据 使 用 该 变量 的 上 下 文 决定 的 。 
例如 ， 通 过 类 型 的 转换 ， 可 将 变量 或 其 所 附带 的 值 转换 成 男 外 一 种 类 型 : 


<?php 
$num = 123; ”// 当 前 是 整数 类 型 
$float = (float) $num; //Snum“ 临 时 性 ”地 转换 成 了 浮 点 型 。 
//$float 变量 所 携带 的 数据 类 型 就 为 浮 点 型 
echo gettype (Snum) . "<br />"; // 使 用 gettype (mixed var) 函数 来 获取 变量 类 型 
echo gettype ($float); 
> 


运行 结果 如 图 2-14 所 示 。 
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文件 ”编辑 EE) 查看 WW 收 意 内 ”工具 C) 帮助 局 
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图 2-14 数据 类 型 的 转换 
每 注意 :要 将 一 变量 彻底 转换 成 另 一 种 类 型 , 需 使 用 settype(mixed var, string type) 函 数 。 


允许 的 强制 转换 的 情形 有 下 列 几 种 。 
@ int、integer: 转换 成 整 型 。 
@ ”bool、boolean: 转换 成 布尔 型 。 
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float、doublereal: 转换 成 浮 点 型 。 
string: 转换 成 字符 串 。 

array: 转换 成 数组 。 

object: 转换 成 对 象 。 


5| PHP 运算 符 


学 过 其 他 语言 的 读者 ， 对 于 运算 符 应 该 不 会 陌生 ， 运 算 符 可 以 用 来 处 理 数字 、 字 符 串 
及 其 他 的 比较 运算 和 逻辑 运算 等 。 在 PHP 中 , 运算 符 两 侧 的 操作 数 会 自动 地 进行 类 型 转换 ， 
这 在 其 他 的 编程 语言 中 并 不 多 见 。 在 PHP 的 编程 中 ， 主 要 有 如 下 三 种 类 型 的 运算 符 。 

e ”一 元 运算 符 ， 只 运算 一 个 值 ， 例 如 !( 取 反 运 算 符 ) 或 ++( 加 1 运算 符 )。 

e 二 元 运算 符 ， PHP 支持 的 大 多 数 运算 符 都 是 这 种 ， 例 如 $a+$b。 

e 三 元 运算 符 : 即 ?:， 被 用 来 根据 一 个 表达 式 的 值 在 另 两 个 表达 式 中 选择 一 个 ， 而 不 

是 用 来 在 两 个 语句 或 者 程序 路 线 中 选择 。 

PHP 中 ， 常 用 的 运算 符 有 算术 运算 符 、 赋 值 运算 符 、 比 较 运 算 符 、 三 元 运算 符 、 错 误 
抑制 运算 符 、 逻 辑 运算 符 、 字 符 串 运算 符 、 数 组 运算 符 等 。 本 节 将 主要 介绍 这 些 常 用 的 运 
算 符 ， 以 及 运算 符 的 优先 级 。 


5.1 算术 运算 符 











算术 运算 符 是 用 来 处 理 四 则 运算 的 符号 ， 是 最 简单 ， 也 最 常用 的 符号 ， 尤 其 是 数字 的 
处 理 ， 几 乎 都 会 使 用 到 算术 运算 符 。PHP 的 算术 运算 符 如 表 2-2 所 示 。 


表 2-2 算术 运算 符 






$a 的 负 值 
$a 与 $b 的 和 
$a 与 $b 的 差 



























站 $a*$b $a 与 $b 的 积 
$a/$b $a 与 $b 的 商 
% $a%$b $a 与 $b 的 余数 





$a++ 


$a 的 递 加 





下 注意 :。 除 号 (/) 总 是 返回 浮 点 数 ， 即 使 两 个 运算 数 是 整数 (或 由 字符 串 转 换 成 的 整数 ) 
也 是 这 样 。 
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5.2 ”赋值 运算 符 

赋值 运算 符 (Assignment OperatoD) 把 表达 式 右边 的 值 赋 给 左边 的 变量 或 常量 。 基 本 的 赋 
值 运算 符 是 “=”, 它 意 味 着 把 右边 表达 式 的 值 赋 给 左边 的 运算 数 。 在 PHP 中 的 赋值 运算 符 
如 表 2-3 所 示 。 
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表 2-3 赋值 运算 符 
符 号 示 例 ;J 
= $a=$b 将 右边 的 值 连 到 左边 
+= Sat+=$b, 将 右边 的 值 加 到 左边 ， 即 $a=$at+$b 
= $a-=$b 将 右边 的 值 减 到 左边 ， 即 $a=$a-$b 
*= $a*=$b 将 左边 的 值 乘 以 右边 ， 即 $a=$a*$b 
上 三 $a/=$b 将 左边 的 值 除 以 右边 ， 即 $a=$a/$Sb 
%= $a%=$b 将 左边 的 值 对 右边 取 余数 ， 即 $a=$a%$b 
= $a.=$b 将 右边 的 字 串 加 到 左边 ， 即 $a=$a.$b 


在 基本 赋值 运算 符 之 外 ， 还 有 适合 于 所 有 二 元 算术 和 字符 串 运算 符 的 “组 合 运算 符 ”， 
这 样 可 以 在 一 个 表达 式 中 使 用 它 的 值 并 把 表达 式 的 结果 赋 给 它 ， 例 如 : 


<?php 
$a = "baidu"; 
$b = ".com"; 


echo $a .= $b; 
> 
运行 结果 如 图 2-15 所 示 。 
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baidu com 





图 2-15 字符 串 赋值 运算 的 结果 


5.3 ”比较 运算 符 


比较 运算 符 ， 顾 名 思 义 就 是 可 用 来 比较 的 操作 符号 ， 根 据 结果 返回 true 或 false。 比 较 
运算 符 允 许 对 两 个 值 进行 比较 ，PHP 的 比较 运算 符 如 表 2-4 所 示 。 
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表 2-4 比较 运算 符 
网 时 3 名 称 意义 
$a=——$b 等 于 : 如 果 $a 等 于 $b 
$a=—$b 全 等 : 如 果 $a 等 于 Sb， 并 且 它 们 的 类 型 也 相同 
$al=$b 不 恒 等 : 如 果 $a 不 恒 等 于 $b 
$a>$b 不 等 于 : 如 果 $a 不 等 于 $b 
$a!==$b 非 全 等 : 如 果 $a 不 等 于 $b， 或 者 它们 的 类 型 不 同 (PHP 4 引进 ) 
$a<$b 小 于 : 如果 $a 严格 小 于 $b 
$a>$b 大 于 : 如 果 $a 严格 大 于 $b 
$a<=$b 小 于 等 于 : 如 果 $a 小 于 或 者 等 于 $b 
$a>=$b 大 于 等 于 : 如 果 $a 大 于 或 者 等 于 $b 
5.4 三 元 运算 符 
三 元 运算 符 是 ?:， 三 元 运算 符 的 功能 与 让 ..else 语句 很 相似 ， 语 法 如 下 : 
(exprl)? (expr2) : (expr3) 


首先 对 exprl 求 值 ， 若 结果 为 True， 则 表达 式 (exprl)? (expr2) : (expr3) 的 值 为 expr2, 否 
则 其 值 为 expr3， 例 如 : 
<?php 
$action = (empty($ POST['action']))? 'default' : $ POST['action']:; 
?> 


这 里 将 首先 判断 $5_POST['action’] 变 量 是 否 为 空 值 ， 若 是 ， 则 给 $action 赋值 为 default， 
否则 将 $_ POST['action"] 变 量 的 值 赋 给 $action。 可 以 将 上 面 的 代码 改写 成 以 下 的 代码 ; 


<?php 
if (empty($ POST['action'])) { 
$action = "default'7 
} else { 


$action = $ POST['action']; 
} 
2> 


5.5 “错误 抑制 运算 符 


抑制 运算 符 可 在 任何 表达 式 前 使 用 ，PHP 支持 一 个 错误 抑制 运算 符 @。 当 将 其 放置 在 
一 个 PHP 表达 式 之 前 时 ， 该 表达 式 可 能 产生 的 任何 错误 信息 都 被 忽略 掉 。@ 运 算 符 只 对 表 
达 式 有 效 。 
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那么 ， 何 时 使 用 此 运算 符 呢 ? 一 个 简单 的 规则 就 是 ， 如 果 能 从 某 处 得 到 值 ， 就 能 在 它 
前 面 加 上 @ 运 算 符 。 例 如 ， 可 以 把 它 放 在 变量 、 函 数 、include0 调 用 、 常 量 之 前 。 不 能 把 它 
放 在 函数 或 类 的 定义 之 前 ， 也 不 能 用 于 条 件 结构 (例如 过 和 foreach 等 )。 

比如 下 面 的 代码 : 


<?php 
$Conn = mysql connect ("localhost", "username", "pwd"); 
if ($Conn) 
echo "连接 成 功 ! "; 
else 
echo "连接 失败 ! "; 
Te 
如 果 mysql_connect() 连 接 失 败 ， 就 显示 系统 的 错误 提示 ， 而 后 继续 执行 下 面 的 程序 。 
如 果 不 想 显示 系统 的 错误 提示 ， 并 希望 失败 后 立即 结束 程序 ， 则 可 以 改写 上 面 的 代码 如 下 : 
<?php 
$Conn = @mysql connect ("localhost", "username", "pwd") 


or die ("连接 数据 库 服务 器 出 错 ") ; 


?> 


在 mysql_connect() 函 数 前 加 上 @ 运 算 符 来 屏蔽 系统 的 错误 提示 ， 同 时 使 用 die(0) 函 数 给 
出 自 定义 的 错误 提示 ， 然 后 立即 退出 程序 。 这 种 用 法 在 大 型 程序 中 很 常见 。 


5.6 ”逻辑 运算 符 


PHP 的 逻辑 运算 符 (Logic Operators) 通 常用 来 测试 真 假 值 ， 常 用 的 逻辑 运算 符 如 表 2-5 
所 示 。 


表 2-5 逻辑 运算 符 






如 果 $a 与 $b 都 为 Tme， 则 结果 为 True 
如 果 $a 与 $b 任 一 为 Tme， 则 结果 为 True 

如 果 $a 与 $b 任 一 为 True， 但 不 同时 为 Trme， 则 结果 为 True 
如 果 $a 不 为 Tme， 则 结果 为 True 

如 果 $a 与 $b 都 为 True， 则 结果 为 True 
如 果 $a 与 $b 任 一 为 Tme， 则 结果 为 True 

























可 以 看 出 ， “与 ”和 “或 ”有 两 种 不 同形 式 的 运算 符 。 
它们 运算 的 优先 级 不 同 ，&& 比 | 的 优先 级 高 。 
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5.7 ”字符 串 运 算 符 


字符 串 运算 符 (String Operator) 有 两 个 。 第 一 个 是 连接 运算 符 “.”， 它 返回 其 左右 参数 
连接 后 的 字符 串 。 第 二 个 是 连接 赋值 运算 符 “一 ”， 它 将 右边 的 参数 附加 到 左边 的 参数 后 。 


例如 : 
<?php 
$a = "你 好 "; 
$a = $a." 朋 友 ! "; ”// 此 时 $a 是 “你 好 朋友 ! ” 
Sb = "你 好 "; 
$b .= "朋友 "; // 此 时 $b 是 “你 好 朋友 ! ” 
2 


5.8 数组 运算 符 


PHP 的 数组 运算 符 如 表 2-6 所 示 。 
表 2-6 数组 运算 符 
意义 
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合 运算 符 “+” 把 右边 的 数组 附加 到 左边 的 数组 后 面 ， 但 重复 的 键 值 不 会 被 覆盖 。 
下 面 通过 一 个 实例 ， 来 看 一 下 如 何 用 “+” 运 算 符 来 联合 两 个 数组 : 


<?php 
$a = array ("1"=>"Nol", "2"=>"No2", "3"=>"No3", "4"=>"No4"); 
$b = array ("3"=>"No3", "4"=>"NOA", "5"=>nNOS", "6"=>"No6"); 
$c = $a + $b; 

print r($c); // 联 合 两 数组 

echo "<br/>"7 

if ($a==$b) 
echo "等 价 "; 

clse 
echo "不 等 价 "; 


> 


可 以 看 到 ， 联 合 之 后 的 数组 结果 如 图 2-16 所 示 。 


5.9 


运算 符 的 优先 级 指定 了 两 个 表达 式 绑 定 得 有 多 “紧密 ” 








图 2-16 


运算 符 的 优先 级 


联合 数组 示例 


话 而 告 磺 加 dHd | | 车 需 


。 例 如 ， 表 达 式 1+2*3 的 结果 


为 7， 是 因为 乘 号 (5 的 优先 级 比 加 号 (+) 高 。 必 要 时 ， 可 以 用 括号 来 强制 改变 优先 级 。 例 如 
(1+2)*3 的 值 为 9。 使 用 括号 也 可 以 增强 代码 的 可 读 性 。 如 果 运 算 符 的 优先 级 相同 ， 则 使 用 
从 左 到 右 的 左 结合 顺序 ( 左 结合 表示 表达 式 从 左 向 右 求 值 ， 右 结合 则 相反 )。 

表 2-7 从 高 到 低 列 出 了 PHP 所 有 运算 符 的 优先 级 。 同 一 行 中 的 运算 符 具 有 相同 的 优先 
级 ， 此 时 ， 它 们 的 结合 方向 决定 求 值 的 顺序 。 
表 2-7 运算 符 的 优先 级 
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下 面 结合 前 面 所 用 到 的 运算 符 ， 来 完成 一 项 需要 综合 使 用 它们 的 任务 : 


<?php 
// 定 义 几 个 常量 ， 最 好 是 使 用 大 写 
define ("PEN"，20); ”// 钢 笔 为 20 元 
define ("RULE"，10); // 尺 子 为 10 元 
Spen num = 10; //10 只 钢笔 
Srule num = 20; //20 把 尺子 
$total price = $pen num*PEN + Srule num*RULE; 
$total price = number format (Stotal price); 
echo "购买 10 只 钢笔 和 20 把 尺子 一 共 要 花 ".$total price." 元 "; 


运行 结果 如 图 2-17 所 示 。 
EE 无 标题 文档 


文件 @) 编辑 EE) 查看 收 意 人 工具 C) 帮助 忌 
; 地 址 加 ) | 图 http://127.0.0. 1/php/paD18. php 口 ~| 





购买 10 只 钢笔 和 20 把 尺子 一 共 要 花 400 元 





2-17 ”运算 符 的 综合 使 用 








6| _ PHP 表达 式 


在 PHP 程序 中 ， 任 何 一 个 可 以 返回 值 的 语句 ， 都 可 以 视 为 表达 式 。 也 就 是 说 ， 表 达 式 
是 一 个 短语 ， 能 够 执行 一 个 动作 并 具有 返回 值 。 一 个 表达 式 通常 由 两 部 分 组 成 ， 一 部 分 是 
操作 数 ， 另 一 部 分 是 运算 符 。 这 里 将 介绍 常用 的 几 种 控制 语句 ， 分 别 是 条 件 语句 、 循 环 语 
句 ， 以 及 require 和 include 语句 等 其 他 语句 。 


6.1 条 件 语句 


条 件 语 句 在 PHP 中 非常 重要 ， 是 PHP 程序 的 主要 控制 语句 之 一 。 通 常情 况 下 ， 在 客户 
端 获得 一 个 参数 , 根据 传 入 的 参数 值 做 出 不 同 的 响应 。 在 PHP 中 , 条 件 语句 分 别 是 让 语句 、 
if-else 语句 、if-elseif-else 语句 和 switch 语句 。 

下 面 我 们 分 别 介绍 这 几 种 形式 的 条 件 语句 。 

1.f 语 句 

让 语句 是 许多 高 级 语言 中 重要 的 控制 语句 ， 使 用 让 语句 ， 可 以 按照 条 件 判 断 来 执行 语 
句 ， 增 强 了 程序 的 可 控制 性 。 
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只 有 让 语句 的 条 件 语句 是 最 简单 的 一 种 条 件 语句 。 
语法 如 下 : 


if (expr) 
statement; 


首先 对 expr 求 值 ， 如 果 expr 的 值 为 tue， 则 执行 statement， 如 果 值 为 false， 将 会 忽略 
statement。 
2-18 给 出 了 上 述 语法 格式 在 执行 时 的 逻辑 结构 。 


Trmue ( 真 ) 
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Start 






False ( 假 ) 


2-18 j 首 语 句 的 逻辑 结构 


例如 : 

<?php 
$Numl = 10; 
SNum2 = 97 


if(SNuml > SNum2) 
echo "SNuml 大 于 $Num2"; 
?> 


这 个 实例 演示 了 直 语 句 的 逻辑 结构 , 会 在 变量 SNuml 大 于 $Num2 时 输出 “$Numl 大 于 
$SNum2”。 
2. if-else 语句 


条 件 语 句 的 第 二 种 形式 是 直 ..else， 即 除了 站 语 句 外 ， 还 加 上 了 else 语句 ，else 语句 可 
在 站 语句 中 表达 式 的 值 为 False 时 执行 。 
语法 如 下 : 


if (expr) 
Statement17 

else 
statement2; 


首先 对 expr 求 值 ， 如 果 expr 的 值 为 True， 则 执行 statement1; 如 果 值 为 False， 则 执行 
Statement2 。 


这 种 情况 的 执行 逻辑 结构 如 图 2-19 所 示 。 
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End 
CE 








False ( 假 ) 


2-19 ”if-else 语句 逻辑 


例如 以 下 代码 ， 在 $a 大 于 $b 时 显示 “a 大 于 b”， 反 之 则 显示 “a 小 于 b”: 


<?php 
$a = 12; 
$b = 49; 
if ($a>$b) 
echo "a 大 于 b"; 
else 
echo "a 小 于 b"; 
2 


狂 注意 : ”else 语句 仅 在 让 以 及 elseif( 如 果 有 的 话 ) 语 名 中 的 表达 式 值 为 False 时 执行 , 它 
不 可 以 单独 使 用 。 


3. if-elseif-else 语句 


条 件 语句 的 第 三 种 形式 是 让 ..elseif ..else，elseif 是 让 和 else 的 结合 。 与 else 一 样 ， 它 
延伸 了 让 语句 , 可 以 在 原来 的 让 表达 式 值 为 False 时 执行 不 同 的 语句 。 但 是 与 else 不 一 样 的 
是 ， 它 仅 在 elseif 的 条 件 表达 式 值 为 True 时 执行 语句 ， 语 法 如 下 : 


if (exprl) 
statementl1; 

elseif (expr2) 
statement2; 

elseif (expr3) 
statement3; 


Bl 
statementn; 
首先 对 exprl 求 值 ， 如 果 exprl 的 值 为 Trme， 则 执行 statement1， 如 果 值 为 False， 则 对 
expr2 求 值 ， 如 果 expr2 的 值 为 True， 则 执行 statement2， 如 果 值 为 False， 则 对 expr3 求 值 ， 
依次 类 推 ， 如 果 所 有 的 表达 式 的 值 都 为 False， 则 执行 statementn 。 
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这 种 情况 的 执行 逻辑 结构 如 图 2-20 所 示 。 
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End 








2-20 ”if-elseif-else 语句 的 逻辑 结构 
例如 ， 以 下 代码 将 根据 条 件 分 别 显示 “a 大 于 b”、“a 等 于 b”、“a 小 于 b”: 


<?php 
if ($a > $b) 
echo "a 大 于 b"; 
elseif ($a == $b) 
echo "a 等 于 b"; 
else 
echo "a 小 于 b"; 
?> 


狂 注意 : elseif 也 可 写成 else (两 个 单词 )， 它 与 elseif( 一 个 单词 ) 的 行为 是 完全 一 样 的 。 
4. switch 语句 


使 用 switch 分 支 语 句 ， 可 以 避免 大 量 地 使 用 if-else 控制 语句 。 

switch 语句 首先 根据 变量 值得 到 一 个 表达 式 的 值 ， 然 后 根据 表达 式 的 值 执行 语句 。 

switch 语句 计算 expression 的 值 , 然后 与 case 后 的 值 做 比较 , 跳 转 到 第 一 个 匹配 的 case 
语句 ,开始 执行 后 面 的 语句 ,如 果 没 有 case 匹配 ,就 跳 转 到 default 语句 执行 , 如 果 没 有 default 
语句 ， 则 退出 。 

当 找 到 匹配 的 时 候 ， 解 析 器 会 一 直 执行 到 switch 结尾 或 者 遇见 break 语句 时 结束 。case 
语句 可 以 使 用 空 语句 。 
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PHP 提供 的 分 支 (switch) 语 句 语 法 如 下 : 


switch (expression) { 

case labell: 
当 expression 等 于 1abell 时 执行 的 代码 ; 
break; 

case label2: 
当 expression 等 于 label12 时 执行 的 代码 ; 
break; 

default: 


当 expression 既 不 等 于 label1 也 不 等 于 label12 时 执行 的 代码 ; 
1 


其 中 的 常量 表达 式 labell 可 以 是 任何 求 值 类 型 的 表达 式 ， 即 整 型 或 浮 点 数 以 及 字符 串 。 
switch 语句 的 逻辑 结构 如 图 2-21 所 示 。 



































Start True ( 真 ) End 
程 和 gE 行 1 各 片段 1 各 结束 
False| ( 假 ) 
True ( 真 ) 
< > 程 片 段 2 
False 〈 假 ) | 
True ( 真 ) 
< > 程 片 段 a 
False| ( 假 ) 





图 2-21 switch 语句 的 逻辑 结构 
下 面 的 代码 是 switch 语句 的 简单 应 用 : 


<?php 
switch ($x) { 
case 1: 
Seho. “x = 2 
break; 
case 2 
echo ~" x = 2 
break; 
CAaSe 35 
echo "x 


人 
break; 


< 0 


default: 
echo "No number between 1 and 3"; 


Cs 


switch 语句 一 行 接 一 行 地 执行 (实际 上 是 语句 接 语句 )。 开 始 时 没有 代码 被 执行 。 仅 当 一 
个 case 语句 中 的 值 与 switch 表达 式 的 值 匹配 时 ，PHP 才 开 始 执行 语句 ， 直 到 switch 的 程序 
段 结束 或 者 遇 到 第 一 个 break 语句 为 止 。 如 果 不 在 case 的 语句 段 最 后 写 上 break 的 话 ，PHP 
将 继续 执行 下 一 个 case 中 的 语句 段 。 

例如 : 


<?php 
Switch ($x) { 
CaSeULS 
echo "x = 1 "2 
Case 2: 
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echo "X = 2"; 
Case 3: 
echo "X = 3"; 
} 
人 


这 里 ， 如 果 $x 等 于 1，PHP 将 执行 所 有 的 输出 语句 ， 如 果 $x 等 于 2，PHP 将 执行 后 面 
两 条 输出 语句 ， 只 有 当 $x 等 于 3 时 ， 才 会 得 到 结果 : x=3。 


6.2 ”循环 语句 


循环 语句 也 称 为 迭代 语句 ， 让 程序 重复 执行 某 个 程序 块 ， 直 到 某 个 特定 的 条 件 表达 式 
结果 为 假 时 ,结束 执行 语句 块 。 在 PHP 中 , 循环 语句 的 形式 有 : while 循环 、do-while 循环 、 
for 循环 和 foreach 循环 。 

1. while 循环 语句 


只 要 指定 的 条 件 成 立 ，while 语句 将 重复 执行 代码 块 ， 如 图 2-22 所 示 。 


False ( 假 ) 







2-22 ”while 循环 语句 的 逻辑 结构 
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while 循环 语句 的 语法 如 下 : 


while (condition) 


需要 被 执行 的 语句 ; 
下 面 的 例子 示范 了 一 个 循环 ， 只 要 变量 i 小 于 或 等 于 3， 代码 就 会 一 直 循 环 执行 下 去 。 
每 循环 一 次 ， 变 量 i 就 会 递增 1: 
<?php 
$i = 1; 
while($i <= 3) { 
Scho "The namber i is ™ » $1 , "br /> 
Si++7 


} 
?> 


程序 执行 的 结果 是 : 


The number is 1 
The number is 2 
The number is 3 


2. do-while 循环 语句 


do...while 语句 会 至 少 执行 一 次 代码 块 ， 然 后 ， 只 要 条 件 成 立 ， 就 会 重复 执行 代码 块 ， 
不 满足 就 跳出 循环 ， 如 图 2-23 所 示 。 


程序 片段 


False( 假 ) 











2-23 ”do-while 循环 语句 的 逻辑 结构 
do-while 循环 语句 的 语法 如 下 : 


do 1{ 

需要 被 执行 的 语句 ; 
} 
while (condition); 


在 下 面 的 例子 中 ， 将 对 1 的 值 进行 累加 ， 然 后 ， 只 要 i 小 于 5 的 条 件 成 立 ， 就 会 继续 累 
加 下 去 : 
<?php 


$i = 0; 
dof{ 
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Si++7 
echo "The mumber is ™ . $1 mw<br />"s 
} 
while ($i < 5); 
> 


程序 执行 的 结果 是 : 


The number is 
The number is 
The number is 
The number is 
The number is 
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3. for 循环 语句 


如 果 已 经 确定 了 代码 块 的 重复 执行 次 数 ， 则 可 以 使 用 for 语句 。 

for 循环 语句 的 语法 如 下 : 

for (initialization; condition; increment) 

要 被 执行 的 语句 ; 

} 

for 语句 中 有 3 个 表达 式 。 第 一 个 表达 式 用 于 初始 化 变量 ， 第 二 个 表达 式 指明 继续 循环 
的 条 件 ， 第 三 个 表达 式 设置 循环 增 量 。 如 果 initialization 或 increment 中 包括 了 多 个 变量 ， 
需要 用 逗号 进行 分 隔 。 而 条 件 必 须 计 算 为 True 或 者 False。 

for 循环 语句 的 逻辑 结构 如 图 2-24 所 示 。 





False( 假 ) 





2-24 for 循环 语句 的 逻辑 结构 


例如 ， 下 面 的 代码 会 把 文本 “Hello World!” 显 示 5 次 : 


<?php 
for ($i=1l; $i<=5; $i++) 
{ 
echo "Hello World!<br />"; 
} 
2> 
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4. foreach 循环 语句 


foreach 语句 用 于 循环 遍历 数组 。 每 进行 一 次 循环 ， 当 前 数组 元 素 的 值 都 会 被 赋值 给 
value 变量 (数组 指针 会 逐一 地 移动 )， 以 此 类 推 。 
语法 如 下 : 


foreach (array as value) 


需要 被 执行 的 语句 ; 
} 


foreach 循环 语句 的 逻辑 结构 如 图 2-25 所 示 。 


| 


False ( 假 ) 










2-25 ”foreach 语句 的 逻辑 结构 


例如 ， 下 面 的 例子 示范 了 一 个 循环 ， 这 个 循环 可 以 输出 给 定数 组 的 值 : 


<?php 
$arr = array ("one", "two", "three"); 
foreach ($arr as $value) 
下 
echo MValues Yo Svalue -<br /> 
} 
?> 


6.3 ”其 他 语句 


为 了 帮助 程序 员 更 加 精确 地 控制 整个 流程 ， 方 便 程序 的 设计 ，PHP 还 提供 了 一 些 其 他 
语句 ， 这 里 做 一 下 简单 的 介绍 。 
1. break 语句 


break 语句 用 来 结束 当前 的 for、while 或 switch 循环 结构 ， 继 续 执行 下 面 的 语句 。break 
语句 后 面 可 以 跟 一 个 数字 ， 用 于 在 嵌 套 的 控制 结构 中 表示 跳出 控制 结构 的 层 数 。 
2. continue 语句 


continue 语句 用 来 跳出 循环 体 , 不 继续 执行 循环 体 下 面 的 语句 ， 而 是 回 到 循环 判断 表达 
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式 ， 并 决定 是 否 继续 执行 循环 体 。continue 语句 后 面 同样 可 以 跟 一 个 数字 ， 作 用 与 break 语 
句 相同 。 
3. return 语句 


return() 语 句 通 常用 于 函数 中 ， 如 果 在 一 个 函数 中 调用 retum0) 语 句 ， 将 立即 结束 此 函数 
的 执行 ， 并 将 它 的 参数 作为 函数 的 值 返 回 。 
4. include() 语 句 和 require() 语 句 


指 包 含 并 运行 指定 的 文件 。require0 和 include0 除 了 处 理 失败 之 外 ， 在 其 他 方面 都 完全 
一 样 。include(0) 产 生 一 个 警告 ， 而 require0 则 导致 一 个 致命 错误 。 也 就 是 说 ， 如 果 想 在 丢失 
文件 时 停止 处 理 页面 ， 应 该 使 用 require0， 而 include0 则 会 继续 执行 脚本 ， 同 时 也 要 确认 设 
置 了 合适 的 include path。 

5. include_once() 语 句 和 require_once() 语 句 


require_once() 语 句 和 include_once() 语 句 分 别 对 应 require(0) 语 句 和 include() 语 句 。 
require_once() 语 句 和 include_once0 语 句 主 要 用 于 需要 包含 多 个 文件 时 ， 可 以 有 效 地 避 
免 把 同一 段 代码 包含 进去 而 出 现 函数 或 变量 重复 定义 的 错误 。 


7|_PHP 函数 的 应 用 


PHP 的 真正 威力 源 于 它 的 函数 。 在 PHP 中 ， 提 供 了 超过 700 个 内 建 的 函数 。 在 本 教程 
中 ， 我 们 将 为 您 讲解 如 何 创建 自己 的 函数 。 


7.1 创建 PHP 函数 


函数 是 一 种 可 以 在 任何 被 需要 的 时 候 执行 的 代码 块 。 创 建 PHP 函数 应 遵循 以 下 规则 : 

@ ”所 有 的 函数 都 使 用 关键 词 function 开始 。 

e 函数 的 名 称 应 该 提示 出 它 的 功能 。 函 数 名 称 以 字母 或 下 划 线 开头 ， 后 面 跟 字母 、 
数字 或 下 划 线 。 

@ 函数 名 后 是 一 对 圆 括 号 ， 其 中 是 可 选 的 参数 列表 ， 可 以 为 空 ， 有 参数 时 ， 参 数 之 
间 用 逗号 分 隔 。 

@ 花 括号 “{” 之 后 的 部 分 是 函数 的 代码 。 

@ 花 括 号 中 需要 插入 执行 功能 的 一 组 代码 语句 。 

@ 函数 通过 关闭 花 括号 “} ”结束 。 

例如 ， 下 面 是 一 个 简单 的 函数 ， 在 其 被 调用 时 ， 能 输出 “David Yang”: 
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<?php 
function writeMyName () // 定 义 函数 
{ 
echo "David Yang"; 
} 
writeMyName (); // 调 用 函数 
?> 


7.2 使 用 PHP 函数 
现在 ， 我 们 可 以 在 PHP 脚本 中 使 用 这 个 函数 了 : 


<?php 
function writeMyName () 
{ 
echo "David Yang"; 
} 
echo "Hello world!<br />"; 
echo "My name is "; writeMyName(); 
echo ".<br />That's right, "; writeMyName(); 
echo " is my name."; 
2 


以 上 代码 的 输出 为 : 


Hello world! 
My name is David Yang. 
That's right, David Yang is my name. 


7.3 添加 函数 参数 


前 面 例子 中 的 第 一 个 函数 是 一 个 非常 简单 的 函数 。 它 只 能 输出 一 个 静态 的 字符 串 。 通 
过 添加 参数 ， 我 们 可 以 为 函数 增加 更 多 的 功能 。 参 数 类 似 一 个 变量 。 读 者 可 能 注意 到 了 ， 
函数 名 称 后 面 有 一 个 括号 ， 比 如 writeMyName()。 参 数 就 是 要 在 括号 中 规定 的 。 

例 1 下 面 的 代码 将 输出 不 同 的 名 字 ， 但 姓 是 相同 的 : 


<?php 
function writeMyName ($fname) 
echo $fname - " Yang.<br />"; 
echo "My name is "; writeMyName ("David"); 
echo "My name is "; writeMyName ("Mike"); 
echo "My name is "7 writeMyName ("John™"); 
2 
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上 面 的 代码 的 输出 : 


My name is David Yang. 
My name is Mike Yang. 
My name is John Yang. 


例 2 下 面 的 函数 有 两 个 参数 : 


<?php 
function writeMyName ($fname, $punctuation) 
业 
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echo $fname . " Yang" . $punctuation . "<br />"; 
} 
echo "My name is "7 
writeMyName ("David", "™."); 
echo "My name is "7 
writeMyName ("Mike", "™!"); 
echo "My name is "7 
writeMyName ("John", "™..."); 
?> 


上 面 的 代码 的 输出 为 


My name is David Yang. 
My name is Mike Yang! 
My name is John Yang... 


7.4 函数 的 返回 值 
所 有 的 函数 都 可 以 有 返回 值 ， 也 可 以 没有 。 例 如 : 


<?php 
function add($x, $y) 
{ 
$total = $x + $y; 
return $total; 
} 
echo, "LiL + 16 = .add(1i,16)s 
人 


以 上 代码 的 输出 为 : 
1 +16=17 
7.5 函数 的 戏 套 和 递归 


PHP 中 的 函数 可 以 嵌 套 定义 和 嵌 套 调用 。 所 谓 嵌 套 定义 ， 就 是 在 定义 一 个 函数 时 ， 其 
函数 体内 又 包含 男 一 个 函数 的 完整 定义 。 这 个 内 嵌 的 函数 只 能 在 包含 它 的 函数 被 调用 之 后 
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才 会 生效 ， 举 例如 下 : 


<?php 
function foo() 
证 
function bar() 
{ 
echo "并 没有 关闭 直到 foo () 函数 被 调用 ."; 


} 
/* 不 能 嵌 套 应 用 bar () 函数 ， 因 为 它 没有 被 关闭 */ 
foo () 7 
/* 现 在 可 以 应 用 bar () 函数 ，foo () 的 进程 允许 使 用 */ 
bar(); 

?> 


这 段 代码 的 输出 为 : 
并 没有 关闭 直到 foo () 函数 被 调用 . 


所 谓 嵌 套 调用 ， 就 是 在 调用 一 个 函数 的 过 程 中 ， 又 调用 另 一 个 函数 。 举 例如 下 : 


<?php 
$numl = 100; 
Snum2 = 200; 
myoutput ($numl, $num2); 
function myoutput ($a, $b) 
业 
echo " 较 大 的 是 " .maxNum ($a，$b); 
} 
function maxNum($a, $b) 
{ 
if ($a<$b) $a =$b; 
return $a; 


(= 


这 段 代 码 的 输出 结果 为 : 
较 大 的 是 200 


PHP 中 还 允许 函数 的 递归 调用 ， 即 在 调用 函数 的 过 程 中 又 直接 或 间接 地 调用 该 函数 本 
身 。 举 例如 下 : 


<?php 
recursion(5); 
function recursion($a) 
{ 
if($a <= 10) { 
echo "$a "7 


< 18 


recursion ($a+1); 


Bs 


这 段 代码 的 输出 结果 为 : 


二 








8| MySQL 数据 库 的 操作 


什么 是 MySQL? MySQL 是 一 种 数据 库 。MySQL 是 目前 最 流行 的 开源 数据 库 服务 器 。 

数据 库 定 义 了 存储 信息 的 结构 。 在 数据 库 中 ， 存 在 着 一 些 表 ， 类 似 HTML 表格 ， 数 据 
库 表 含 有 行 、 列 以 及 单元 。 在 分 类 存储 信息 时 ， 数 据 库 非 常 有 用 。 一 个 公司 的 数据 库 可 能 
拥有 下 面 这 些 表 : Employees、Products、Customers 以 及 Orders。 

数据 库 通 常 包 含 一 个 或 多 个 表 。 每 个 表 都 一 个 名 称 (比如 Customers 或 Orders)， 每 个 表 
包含 带 有 数据 的 记录 ( 行 )。 表 2-8 是 一 个 名 为 Persons 的 表 的 例子 。 


表 2-8 Persons 表 





LastName 


Svendson 


Pettersen 





上 面 的 表 含 有 3 个 记录 (每 个 记录 是 一 个 人 ) 和 4 个 列 (LastName、FirstName、Address 
以 及 City)。 

查询 是 一 种 询问 或 请 求 。 通 过 MySQL， 我 们 可 以 从 数据 库 中 查询 具体 的 信息 ， 并 得 到 
返回 的 记录 集 。 看 下 面 的 查询 : 


SELECT LastName FROM Persons 


上 面 的 查询 选取 了 Persons 表 中 LastName 列 的 所 有 数据 ， 将 返回 类 似 这 样 的 记录 集 : 


LastName 


Hansen 
Svendson 
Pettersen 


如 果 我 们 的 PHP 服务 器 没有 MySQL 数据 库 ， 可 以 从 如 下 网 址 下 载 MySQL: 


http://www.mysql.com/downloads/index.html 
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8.1 


连接 数据 库 
在 能 够 访问 并 处 理 数据 库 中 的 数据 之 前 ， 我 们 必须 创建 到 达 数 据 库 的 连接 。 
在 PHP 中 ， 这 个 任务 通过 mysql_connect() 函 数 来 完成 。 语 法 如 下 : 


mysql connect (servername, username, password); 


其 中 : 

@ servername: 可 选 。 规 定 要 连接 的 服务 器 。 默 认 是 localhost:3306。 

e@ username: 可 选 。 登 录 所 使 用 的 用 户 名 。 默 认 值 是 拥有 服务 器 进程 的 用 户 的 名 称 。 
@ ”password: 可 选 。 登 录 所 用 的 密码 。 默 认为 空 。 

虽然 还 存在 其 他 的 参数 ， 但 上 面 列 出 了 最 重要 的 参数 。 

在 下 面 的 例子 中 ,我 们 在 一 个 变量 ($con) 中 存放 了 在 脚本 中 供 稍 后 使 用 的 连接 。 如 果 连 


接 失 败 ， 将 执行 die 部 分 : 


<?php 
$con = mysql connect ("localhost", "peter", "abcl23"); 
if (!$con) 
{ 
die('Could not connect: ' . mysql error()); 


} 
// some code 
> 


脚本 一 结束 ， 就 会 关闭 连接 。 要 提前 关闭 连接 ， 可 使 用 mysql_close() 函 数 : 


<?php 
$con = mysql connect ("localhost", "peter", "abcl23"); 
EE (lScon) 
die('Could not connect: ' . mysql error()); 
} 
// some code 
mysql close($con); 
2 


8.2 创建 数据 库 和 表 


数据 库 中 含有 一 个 或 多 个 表 。 使 用 CREATE DATABASE 语句 在 MySQL 中 创建 数据 库 。 
语法 如 下 : 


CREATE DATABASE database name 


为 了 让 PHP 执行 上 面 的 语句 , 我 们 必须 使 用 mysql_query0 函 数 。 此 函数 用 于 向 MySQL 





连接 发 送 查 询 或 命令 。 
在 下 面 的 代码 中 ， 创 建 了 一 个 名 为 “my_ db” 的 数据 库 : 


<?php 
$con = mysql connect ("localhost", "peter", "abcl23"); 
if (!$con) 
{ 
die('Could not connect: ' . mysql error()); 
} 
if (mysql query("CREATE DATABASE my db", $con)) 
{ 
echo "Database created"; 
} 
else 
{ 
echo "Error creating database: " . mysql error(); 
} 
mysql close($con); 


CREATE TABLE 用 于 在 MySQL 中 创建 数据 库 表 。 
语法 如 下 : 


CREATE TABLE table name 

( 
column namel data type, 
column name2 data type, 
column name3 data type, 


) 


为 了 执行 此 命令 ， 必 须 向 mysql_query0) 函 数 添加 CREATE TABLE 语句 。 
下 面 的 例子 展示 了 如 何 创建 一 个 名 为 Persons 的 表 ， 此 表 有 三 列 ， 列 名 是 FirstName、 
LastName 以 及 Age: 


<?php 
$con = mysql connect ("localhost", "peter", "abcl23"); 
if (!$con) 


i 
die('Could not connect: ' . mysql error()); 


// Create database 
if (mysql query ("CREATE DATABASE my db", $con)) 
{ 

echo "Database created"; 


} 
else 
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{ 
echo "Error creating database: " . mysql error(); 
} 
// Create table in my db database 
mysql select db("my db", $con); 
$sql = "CREATE TABLE Persons 
( 
FirstName Varchar (15) ， 
LastName Varchar (15) ， 
Age int 
2 
mysql query($sql, $con); 
mysql close($con); 
i 


在 创建 表 之 前 ， 必 须 先 选择 数据 库 。 通 过 mysql_select_db0 函 数 选取 数据 库 。 当 创建 


varchar 类 型 的 数据 库 字 段 时 ， 必 须 规定 该 字段 的 最 大 长 度 ， 例 如 varchar(15)。 


int(size 


表 2-9 ~ 2-12 给 出 了 可 使 用 的 各 种 MySQL 数据 类 型 。 
表 2-9 数值 类 型 
数值 类 型 描 述 


smallint(size) 


tinyint(size) 仅 支持 整数 。 在 size 参数 中 规定 数值 的 最 大 值 


mediumint(size) 


bigint(size) 
decimal(size, d) 支持 带 有 小 数 的 数值 。 


double(size, d) 在 size 参数 中 规定 数值 的 最 大 值 。 在 d 参数 中 规定 小 数 点 右 侧 的 数值 的 








float(size, d) 最 大 值 


表 2-10 文本 数据 类 型 


文本 数据 类 型 描 述 


支持 固定 长 度 的 字符 串 (可 包含 字母 、 数 字 以 及 特殊 符号 )。 在 size 参数 中 


char(size) 














规定 固定 长 度 

var 支持 可 变 长 度 的 字符 串 ( 可 包含 字母 、 数 字 以 及 特殊 符号 )。 在 size 参数 中 
规定 最 大 长 度 

tinytext 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 255 个 字符 

textblob 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 65535 个 字符 

mediumtext mediumblob 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 16777215 个 字符 

longtextlongblob 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 4294967295 个 字符 
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表 2-11 日 期 数据 类 型 


日 期 数据 类 型 
date(yyyy-mm-dd) 
datetime(yyyy-mm-dd hh:mm:ss) 
timestamp(yyyymmddhhmmss) 








支持 日 期 或 时 间 








time(hh:mm:ss, 


表 2-12 杂项 数据 类 型 
杂项 数据 类 型 


enum(valuel, value2, ...) 


描 述 
enum 是 enumerated 枚 举 列表 的 缩写 。 可 以 在 括号 中 存放 最 
多 65535 个 值 
set 与 enum 相似 。 但 set 可 拥有 最 多 64 个 列表 项 目 , 并 可 存 
放 不 止 一 个 choice 





set 





每 个 表 都 应 有 一 个 主键 字段 。 主 键 用 于 对 表 中 的 行进 行 唯一 标识 。 每 个 主键 值 在 表 中 
必须 是 唯一 的 。 此 外 ， 主 键 字 段 不 能 为 空 ， 这 是 由 于 数据 库 引 擎 需要 一 个 值 来 对 记录 进行 
定位 。 

主键 字段 永远 要 被 编 入 索引 ， 这 条 规则 没有 例外 。 必 须 对 主键 字段 进行 索引 ， 这 样 ， 
数据 库 引 擎 才能 快速 找到 给 予 该 键 值 的 行 。 

下 面 的 例子 把 personID 字段 设置 为 主键 字段 : 


$sql = "CREATE TABLE Persons 
( 
personID int NOT NULL AUTO INCREMENT, 
PRIMARY KEY (personID), 
FirstName varchar(15), 
LastName varchar(15), 
Age int 
ye 


mysql_query ($sql, $con); 


主键 字段 通常 是 ID 号 ， 且 通常 使 用 AUTO_INCREMENT 设置 。AUTO _INCREMENT 
会 在 新 记录 被 添加 时 逐一 增加 该 字段 的 值 。 要 确保 主键 字段 不 为 空 ， 我 们 必须 向 该 字段 添 
加 NOT NULL 设置 。 


8.3 插入 数据 


INSERT INTO 语句 用 于 向 数据 库 表 中 添加 新 记录 。 语 法 如 下 : 


INSERT INTO table name VALUES (valuel, value2, ...) 
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还 可 以 规定 希望 在 其 中 插入 数据 的 列 。 语 法 如 下 : 
INSERT INTO table name (columnl, column2, ...) VALUES (valuel, value2, ...) 


SQL 语句 对 大 小 写 不 敏感 ，INSERT INTO 与 insert into 作用 相同 。 为 了 让 PHP 执行 该 
语句 ， 我 们 必须 使 用 mysql_query0 函 数 ， 该 函数 用 于 向 MySQL 连接 发 送 查 询 或 命令 。 

例如 ， 在 前 面 的 内 容 中 ， 我 们 创建 过 一 个 名 为 Persons 的 表 ， 有 3 个 列 : Firstname、 
Lastname 以 及 Age， 我 们 将 在 本 例 中 使 用 同样 的 表 。 

下 面 的 例子 向 Persons 表 中 添加 两 条 新 记录 : 


<?php 
$con = mysql connect ("localhost", "peter", "abcl23"); 
if (!$con) 


{ 
die('Could not connect: ' . mysql error()); 

} 

mysql select db("my db", $con); 

mysql query("INSERT INTO Persons (FirstName, LastName, Age) 
VALUES ('Peter', "Griffin', '35°')"); 

mysql query("INSERT INTO Persons (FirstName, LastName, Age) 
VALUES ('Glenn', 'Quagmire', '33')"); 

mysql close($con); 

?> 


下 面 顺便 说 明 如 何 把 来 自 表单 的 数据 插入 数据 库 。 
首先 创建 一 个 HTML 表单 ， 这 个 表单 可 把 新 记录 插入 Persons 表 : 


<html> 

<body> 

<form action="insert.php" method="post"> 
Firstname: <input type="text" name="firstname" /> 
Lastname: <input type="text" name="lastname" /> 
Age: <input type="text" name="age" /> 
<input type="submit" /> 

</form> 

</body> 

</html> 


当 用 户 单 击 HTML 表单 中 的 提交 按钮 时 , 表单 数据 被 发 送 到 insertphp。 文 件 insert.php 
可 以 连接 数据 库 ， 并且 通过 $_POST 变量 从 表单 取 回 值 。 然后， 由 mysql_queryO 函 数 来 执行 
INSERT INTO 语句 ， 一 条 新 的 记录 就 会 添加 到 数据 库 表 中 。 

下 面 是 insertphp 页 面 的 代码 : 


<?php 
$con = mysql connect ("localhost", "peter", "abcl23"); 
(on 
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{ 
die('Could not connect: ' . mysql error()); 

} 
mysql select db("my db", $con); 
$sql = "INSERT INTO Persons (FirstName, LastName, Age) 

VALUES ('$ POST[firstname]','$ POST[lastname]','$ POST[age]')"7 
if (!mysql query($sql, $con)) 
{ 
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die('Error: ' . mysql error()); 
} 
echo "1 record added"; 
mysql close($con) 
> 


8.4 选取 数据 


SELECT 语句 用 于 从 数据 库 中 选取 数据 。 
语法 如 下 : 


SELECT column name(s) FROM table name 


SQL 语句 对 大 小 写 不 敏感 ， 即 SELECT 与 select 是 等 效 的 。 

为 了 让 PHP 执行 上 面 的 语句 , 我 们 必须 使 用 mysql_query0) 函 数 。 该 函数 用 于 向 MySQL 
发 送 查询 或 命令 。 

例如 ， 选 取 存 储 在 Persons 表 中 的 所 有 数据 (* 字 符 的 含义 是 选取 表 中 的 所 有 数据 ): 


<?php 
$con = mysql connect ("localhost", "peter", "abcl23"); 
if (!$con) 


{ 
die('Could not connect: ' . mysql error()); 
下 
mysql select db("my db", $con); 
$result = mysql query("SELECT * FROM Persons"); 
while (Srow = mysql fetch array ($result)) 
{ 
echo $row['FirstName'] . " " . $row['LastName']; 
echo "<br />"; 
} 
mysql close($con); 
?2> 


上 面 这 个 例子 首先 在 $result 变量 中 存放 由 mysql query0 函 数 返 回 的 数据 ， 然 后 ， 使 用 
mysql_fetch_array() 函 数 以 数组 的 形式 从 记录 和 集 返 回 第 一 行 。 每 个 随后 对 mysql_fetch_array() 
函数 的 调用 都 会 返回 记录 集中 的 下 一 行 。while 循环 语句 会 循环 显示 记录 集中 的 所 有 记录 。 
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为 了 输出 每 行 的 值 ， 我 们 使 用 PHP 的 $row 变量 ($row['FirstName’] 和 $row[‘LastName’])。 
以 上 代码 的 输出 结果 为 : 


Peter Griffin 
Glenn Quagmire 


下 面 的 例子 选取 的 数据 与 上 面 的 例子 相同 ， 只 是 将 把 数据 显示 在 一 个 HTML 表格 中 : 


<?php 
$con = mysql connect ("localhost", "peter", "abcl23"); 
if (!$con) 


{ 
die('Could not connect: ' . mysql error()); 
} 
mysql select db ("my db", $con); 
$result = mysql query("SELECT * FROM Persons"); 
echo "<table border="'1'><tr><th>Firstname</th><th>Lastname</th></tr>"; 
while($row = mysql fetch array ($result)) 
echo "<tr>"; 
echo "<td>" . $row['FirstName'] . "</td>"; 
echo "<td>" . $row['LastName'] . "</td>"; 
echo "</tr>"; 
} 
echo "</table>"; 
mysql close($con); 
> 


以 上 代码 的 输出 结果 如 图 2-26 所 示 。 


Firstname Lastname 


Glem Quagmire 
Peter Griffin 
图 2-26 输出 结果 


8.5 条 件 查询 
如 需 选 取 匹 配 指定 条 件 的 数据 ， 可 向 SELECT 语句 添加 WHERE 子 句 。 语 法 如 下 : 


SELECT column FROM table WHERE column operator Value 


下 列 运算 符 可 与 WHERE 子 句 一 起 使 用 。 


@ =: 等于。 
D2 es 不 等 于 。 
e@ >: 大 于 。 
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<: 小 于 。 

>=: 大 于 或 等 于 。 

<=: 小 于 或 等 于 。 

BETWEEN: 介 于 一 个 包含 范围 内 。 

LIKE: 搜索 匹配 的 模式 。 

SQL 语句 对 大 小 写 不 敏感 ， 即 WHERE 与 where 的 作用 是 等 效 的 。 
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为 了 让 PHP 执行 上 面 的 语句 ， 我 们 必须 使 用 mysql_query0 函 数 。 该 函数 用 于 向 SQL 


连接 发 送 查询 和 命令 。 


下 面 的 例子 将 从 Persons 表 中 选取 所 有 FirstName = "Peter 的 行 : 


<?php 

$con = mysql connect ("localhost", "peter", "abcl23"); 

if (!$con) { 
die('Could not connect: ' . mysql error()); 

} 

mysql select db ("my db", $con); 

$result = mysql query("SELECT * FROM Persons 

WHERE FirstName = 'Peter'"); 

while($row = mysql fetch array ($result)) { 
echo $row['FirstName'] . " " . $row['LastName']; 
echo "<br />"; 


E22 


以 上 代码 的 输出 为 : 


Peter Griffin 


8.6 数据 排序 


ORDER BY 关键 词 用 于 对 记录 集中 的 数据 进行 排序 。 
语法 如 下 : 


SELECT column name(s) FROM table name ORDER BY column name 


SQL 对 大 小 写 不 敏感 。 即 ORDER BY 与 order by 是 等 效 的 。 
例如 ， 选 取 Persons 表 中 存储 的 所 有 数据 ， 并 根据 Age 列 对 结果 进行 排序 : 


<?php 
$con = mysql connect ("localhost", "peter", "abcl23"); 
if (!$con) 
{ 
die('Could not connect: ' - mysql error()); 
} 
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mysql select db("my db", $con); 
$result = mysql query("SELECT * FROM Persons ORDER BY Age"); 
while (Srow = mysql fetch array ($result)) 
{ 
echo $row['FirstName']; 
echo " " . $row['LastName']; 
echo " " . $row['Age']; 
echo "<br />"; 
} 
mysql close($con); 
i 


以 上 代码 的 输出 结果 如 下 : 


Glenn Quagmire 33 
Peter Griffin 35 


在 使 用 ORDER BY 关键 词 的 时 候 ， 应 记 住 记 录 集 的 排序 顺序 默认 是 升序 (例如 1 在 9 
之 前 ，a 在 p 之 前 )。 
可 以 使 用 DESC 关键 词 来 设 定 降序 排序 (例如 9 在 1 之 前 , p 在 a 之 前 ): 


SELECT column name(s) 
FROM table name 
ORDER BY column name DESC 


可 以 根据 两 列 进行 排序 ， 也 可 以 根据 多 个 列 进行 排序 。 当 按照 多 个 列 进行 排序 时 ， 只 
有 第 一 列 相 同时 ， 才 使 用 第 二 列 。 语 法 如 下 : 


SELECT column name(s) 
FROM table name 
ORDER BY column namel, column name2 


8.7 ”更 新 数据 


UPDATE 语句 用 于 在 数据 库 表 中 修改 数据 。 
语法 如 下 : 


UPDATE table name 
SET column name = new value 
WHERE column name = some value 


SQL 对 大 小 写 不 敏感 ， 即 UPDATE 与 update 是 等 效 的 。 

为 了 让 PHP 执行 上 面 的 语句 ,必须 使 用 mysql query() 函 数 , 该 函数 用 于 向 SQL 连接 发 
送 查 询 和 命令 。 

例如 ， 我 们 先前 创建 过 的 一 个 名 为 Persons 的 表 ， 该 表 的 结构 类 似 于 表 2-13。 
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表 2-13 Persons 表 








了 
志 
FirstName 
的 
本 
加 
下 面 的 例子 更 新 Persons 表 的 一 些 数 据 : 
<?php 
$con = mysql connect ("localhost", "peter", "abcl23"); 
if (!$con) 


{ 
die('Could not connect: ' . mysql error()); 
} 
mysql select db ("my db", $con); 
mysql query ("UPDATE Persons SET Age = '36" 
WHERE FirstName = 'Peter' AND LastName = 'Griffin'"); 
mysql close($con); 
?> 


在 这 次 更 新 后 ，Persons 表格 如 表 2-14 所 示 。 
表 2-14 更 新 后 的 Persons 表 


FirstName 





8.8 删除 数据 


DELETE FROM 语句 用 于 从 数据 库 表 中 删除 记录 。 
语法 如 下 : 

DELETE FROM table name 

WHERE column name = some value 


SQL 对 大 小 写 不 敏感 ， 即 DELETE FROM 与 delete from 是 等 效 的 。 

为 了 让 PHP 执行 上 面 的 语句 , 必须 使 用 mysql_ query0 函 数 。 该 函数 用 于 向 SQL 连接 发 
送 查 询 和 命令 。 

例如 ， 针对 如 表 2-13 所 示 的 Persons 表 ， 下面 的 代码 删除 Persons 表 中 所 有 LastName = 
“Griffin* 的 记录 : 


<?php 
$con = mysql connect ("localhost", "peter", "abcl23"); 
En 
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die('Could not connect: 


} 
mysql select db ("my db", $con); 
mysql query ("DELETE FROM Persons WHERE LastName="'Griffin'™"); 


mYSql error())y 


mysql close($con); 
YE 


在 这 次 删除 之 后 ，Persons 表 变 成 如 表 2-15 所 示 。 
表 2-15 删除 记录 后 的 Persons 表 


FirstName LastName Age 
Glenn Quagmire 33 


本 模块 介绍 了 PHP 与 MySQL 数据 库 的 一 些 常用 操作 ， 读 者 在 学 习 的 时 候 一 定 要 认真 
编写 每 一 行 的 代码 ， 养 成 规范 编程 的 习惯 ， 以 方便 对 后 面 内 容 的 学 习 。 
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模块 三 


价格 查询 系统 实例 的 设计 





进行 PHP 网 站 开发 的 环境 很 多 ， 已 经 很 熟悉 HTML 语言 和 PHP 
的 设计 人 员 ， 甚 至 可 以 直接 使 用 记事 本 进行 代码 的 编写 工作 。 而 对 于 
新 手 来 说 ,可 以 使 用 Dreamweaver 配合 MySQL 进行 动态 系统 的 开发 。 

Dreamweaver 提 供 了 方便 易 用 的 图 形 化 界面 ,只 需 使 用 鼠标 选择 ， 
输入 一 些 基 本 设置 参数 ， 就 能 够 与 MySQL 数据 库 交互 ， 实 现 建 立 数 
据 库 、 查 询 、 新 增 记 录 、 更 新 记录 、 删 除 记录 等 操作 ， 不 用 自己 写 程 
序 即 可 实现 PHP + MySQL 动态 系统 的 开发 。 

本 章 将 介绍 如 何 使 用 Dreamweaver 的 服务 器 行为 , 引导 读者 熟悉 
由 Dreamweaver 产生 的 程序 代码 ,掌握 Dreamweaver 绑 定 生成 的 PHP 
程序 逻辑 。 


。 本 模块 的 任务 重点 。 








掌握 以 Dreamweaver 进行 PHP 开发 的 流程 
在 Dreamweaver 中 进行 PHP 开发 平台 的 搭建 
搭建 PHP 动态 系统 开发 的 平台 

检查 数据 库 记 录 的 常见 操作 

编辑 记录 的 常见 操作 
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国 1 | 搭建 PHP 开发 环境 


Dreamweaver 提供 了 网 站 开发 的 整合 性 环境 ， 它 可 以 支持 不 同 服务 器 技术 ， 如 ASP、 
PHP、JSP 等 ， 建 立 支持 数据 库 的 动态 网 络 应 用 程序 ， 同 时 ， 也 能 让 不 懂得 程序 代码 的 网 站 
设计 人 员 或 初学 者 在 不 用 撰写 程序 代码 的 情况 下 ， 学 习 动 态 网 页 的 设计 技术 。 


1.1 网 站 开发 的 步骤 


在 开始 制作 网 站 之 前 , 还 要 了 解 在 Dreamweaver CS5.5 中 的 网 页 设计 和 发 布 流程 ,可 以 
分 为 如 下 5 个 步骤 。 

(1) 规划 网 站 站 点 

需要 了 解 网 站 建设 的 目的 ， 确 定 网 站 提供 的 服务 、 针 对 的 是 什么 样 的 访问 者 ， 以 决定 
网 页 中 应 该 出 现 什么 内 容 。 

(2) 建立 站 点 的 基本 结构 

在 Dreamweaver CS5.5 中 , 可 以 在 本 地 计算 机 上 建立 出 整个 站 点 的 框架 ,并 在 各 个 文件 
夹 中 合理 地 安置 文档 。Dreamweaver CS5.5 可 以 在 站 点 窗口 中 以 两 种 方式 显示 站 点 结构 ， 一 
种 是 目录 结构 ， 另 一 种 是 站 点 地 图 。 可 以 使 用 站 点 地 图 的 方式 快速 构建 和 查看 站 点 原型 。 
一 旦 创建 了 本 地 站 点 并 生成 了 相应 的 站 点 结构 、 创 建 了 即将 进一步 编辑 的 各 种 文档 ， 就 可 
以 在 其 中 组 织 文 档 和 数据 了 。 

(3) 实现 所 有 页 面 的 设计 

建立 站 点 之 后 ， 进 入 Dreamweaver CS5.5 软件 中 ,开始 进行 页 面 的 版 面 规划 设计 , 利用 
强大 的 编辑 设计 功能 实现 各 种 复杂 的 表格 ， 然 后 再 组 织 页 面 内 容 。 为 了 保持 页 面 的 统一 风 
格 ， 可 以 利用 模板 来 快速 生成 文档 。 

(4) 充实 网 页 内 容 

在 创建 了 基本 版 面 页 面 之 后 ， 就 要 往 框架 里 填充 内 容 了 。 在 文档 窗口 中 合适 的 地 方 ， 
可 以 输入 文字 和 其 他 资源 ， 例 如 图 像 、 水 平 线 、Flash 插件 和 其 他 对 象 ， 一 般 可 以 通过 插入 
面板 或 插入 菜单 来 完成 插入 操作 。 

(5) 发 布 和 维护 更 新 

在 站 点 编辑 完成 后 ， 需 要 将 本 地 的 站 点 跟 位 于 Internet 服务 器 上 的 远程 站 点 关联 起 来 ， 
把 本 地 设计 好 的 网 站 内 容 传 到 服务 器 上 ， 并 注意 后 期 的 随时 更 新 和 维护 。 


1.2 ”网 站 文件 来 的 设计 
在 制作 网 站 之 前 ， 首 先 要 把 设计 好 的 网 站 内 容 放置 在 本 地 设计 的 计算 机 硬盘 上 ， 为 了 
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方便 站 点 的 设计 及 上 传 ， 设 计 好 的 网 页 都 应 存储 在 Apache 服务 器 的 安装 路 径 下 ， 如 本 书 中 
的 路 径 为 C:\Apache\hedocs 目录 下 ， 再 用 合理 的 文件 夹 来 管理 文档 。 在 本 地 站 点 规划 时 ， 应 
该 注意 下 列 操作 规则 。 

1. 设计 合理 的 文件 来 


在 本 地 站 点 中 应 该 用 文件 夹 来 合理 构建 文档 的 结构 ， 首 先 为 站 点 创建 一 个 主要 文件 来， 
然后 在 其 中 创建 多 个 子 文件 夹 , 最 后 将 文档 分 类 存储 在 相应 的 文件 夹 下 。 例如 可 以 在 images 
的 文件 夹 中 放置 网 站 页 面 的 图 片 , 可 以 在 data 文件 夹 中 放置 网 站 的 数据 库 , 可 以 在 css 文件 
夹 中 放置 网 页 的 样式 表 ， 如 图 3-1 所 示 为 一 个 phpweb 网 站 规划 建立 的 文件 夹 和 文档 。 


和 C:\Apache\htdocs\phpweb 
文件 四 ”编辑 人 E) 查看 WW 收 茧 引 ， 工具 0 帮助 四 
昌 恨 -利和 店 吕 扫 家 昌文 和 天 回 - 

地 址 四 ) 加 c;\Apache\htdocs\phpreb 





字 友 器 弄 特 哈 济世 四 蜂 纪 ”|| 绪 匡 


文件 和 文件 来 任务 


四 凶 蛙 一 个 新 文件 天 
人 朱 这 1 文人 到 


em | 日 日 日 日 罩 








addphp delphp dateil.php index.php update php 








图 3-1 网 站 在 本 地 硬盘 上 的 文件 夹 和 文档 
2. 设计 合理 的 文件 夹 名 称 


网 站 建设 由 于 要 产生 的 文件 很 多 ， 因 此 要 用 合理 的 文件 名 称 ， 这 样 操作 的 目的 ， 一 是 
为 了 方便 在 网 站 的 规模 变 得 很 大 时 ， 可 以 进行 修改 更 新 ， 二 是 为 了 方便 浏览 者 通过 查看 网 
页 的 文件 名 就 能 知道 网 页 所 要 表达 的 内 容 。 
在 设计 合理 的 文件 名 时 ， 要 注意 以 下 几 点 : 
®@ ”尽量 使 用 短文 件 名 来 命名 。 
@ ”应 该 避免 使 用 中 文 文件 名 ， 因 为 很 多 Intemet 服务 器 使 用 的 是 英文 操作 系统 ， 不 能 
对 中 文 文件 名 提供 很 好 的 支持 ， 而 且 浏览 网 站 的 用 户 也 可 能 使 用 英文 操作 系统 ， 
用 中 文 文件 名 同样 可 能 导致 浏览 错误 或 访问 失败 。 
@ ”建议 在 构建 的 站 点 中 ， 全 部 使 用 小 写 的 文件 名 称 。 很 多 Internet 服务 器 采用 Unix 
操作 系统 ， 它 是 区 分 文件 的 大 小 写 的 。 
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3. 设计 本 地 和 远程 站 点 为 相同 的 文件 结构 


这 是 指 在 本 地 站 点 中 规划 设计 的 网 站 文件 结构 要 与 上 传 到 Intemet 服 务 器 中 被 人 浏览 的 
网 站 文件 结构 相同 。 这 样 ， 在 本 地 站 点 上 相应 的 文件 夹 和 文件 上 的 操作 ， 都 可 以 同 远程 站 
点 上 的 文件 夹 和 文件 一 一 对 应 。Dreamweaver CS5.5 将 整个 站 点 上 传 到 Intemet 服务 器 上 ， 
可 以 保证 远程 站 点 是 本 地 站 点 的 完整 的 复制 ， 方 便 浏览 和 修改 。 


1.3 流畅 的 浏览 顺序 


在 创建 网 站 的 时 候 ， 首 先 要 考虑 到 所 有 页 面 的 浏览 顺序 ， 注 意 主 次 页 面 之 间 的 链接 是 
否 流畅 。 如 果 采 用 标准 统一 的 网 页 组 织 形式 ， 可 以 让 用 户 轻松 自如 地 访问 每 个 他 们 要 访问 
的 网 页 ， 这 样 就 能 提高 浏览 的 兴趣 、 加 大 网 站 的 访问 量 。 

建立 站 点 的 浏览 顺序 时 ， 要 注意 如 下 几 个 方面 的 要 求 。 

(1) 在 每 个 页 面 中 建立 主页 的 链接 

在 网 站 所 有 的 页 面 上 ， 都 要 放置 返回 主页 的 链接 。 通 过 在 网 页 中 包含 主页 的 链接 ， 就 
可 以 保证 用 户 在 不 知道 自己 目前 位 置 的 情况 下 ， 能 快速 返回 到 主页 中 ， 重 新 开始 浏览 站 点 
中 的 其 他 内 容 。 

(2) 建立 网 站 导航 

应 该 在 网 站 任何 一 个 页 面 上 建立 网 站 导航 ， 通 过 导航 提供 站 点 的 简明 目录 结构 ， 引 导 
用 户 从 一 个 页 面 快速 进入 到 其 他 页 面 上 。 

(3) 突出 当前 页 的 位 置 

在 网 站 页 面 的 设计 中 ， 往 往 需要 加 入 当前 页 在 网 站 中 的 位 置 说 明 ， 或 者 是 加 入 说 明 的 
主题 ， 以 帮助 浏览 者 了 解 他 们 现在 访问 的 是 什么 地 方 。 如 果 页 面 嵌 套 过 多 ， 则 可 以 通过 创 
建 “ 前 进 ”、“ 后 退 ” 之 类 的 链接 ， 来 帮助 浏览 者 进行 浏览 。 

(4) 增加 搜索 和 索引 功能 

对 于 一 些 带 数据 库 的 网 站 ， 还 应 该 给 浏览 者 提供 搜索 的 功能 ， 或 者 是 给 浏览 者 检索 的 
权利 ， 使 用 户 能 快速 查找 到 自己 需要 的 信息 。 

(5) 必要 的 信息 反馈 功能 

网 站 建设 和 发 布 后 ， 都 会 存在 一 些小 问题 ， 从 浏览 者 那里 及 时 获取 他 们 对 网 站 的 意见 
和 建议 是 非常 必要 的 ， 为 了 及 时 地 从 用 户 处 了 解 到 相关 的 信息 ， 应 该 在 网 页 上 提供 用 户 同 
网 页 创作 者 或 网 站 管理 员 的 联系 途径 。 常 用 的 方法 是 建立 留言 簿 或 是 创建 一 个 E-mail 超级 
链接 ， 帮 助 用 户 快速 地 将 信息 回馈 到 网 站 中 。 
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国 :| 价格 查询 系统 的 设计 


这 里 以 价格 查询 系统 实例 的 形式 具体 介绍 Dreamweaver 中 的 服务 器 行为 的 使 用 方法 。 
在 开始 制作 一 个 PHP 网 站 之 前 ， 需 要 在 Dreamweaver 中 定义 一 个 新 站 点 。 在 新 建站 点 时 可 
以 让 Dreamweaver 知道 当前 网 站 的 具体 目录 、 测 试 的 路 径 等 信息 。 


2.1 网 站 的 整体 结构 


价格 查询 系统 的 结构 主要 分 成 用 户 登 录入 口 和 找 回 密码 入 口 两 个 部 分 ，index.php 是 这 
个 网 站 的 首页 。 

在 本 地 计算 机 中 设置 站 点 服务 器 .除了 在 Dreamweaver CS5.5 的 网 站 环境 按 F12 键 来 浏 
览 网 页 外 ， 还 可 以 在 正 浏 览 器 中 输入 “http://localhost/web/index.php” 来 打开 用 户 系统 的 首 
页 index.php， 其 中 web 为 站 点 名 。 

本 实例 制作 5 个 功能 页 面 ， 各 页 面 的 功能 如 表 3-1 所 示 。 





生 友 器 弄 特 叭 淋 蕊 四 蜂 纪 ”|| 红 项 


表 3-1 网 页 的 功能 
页 面 主要 的 功能 
index.php 显示 所 有 的 价格 记录 
detail.php 显示 详细 价格 信息 页 面 
add.php 增加 价格 信息 页 面 
update.php 更 新 价格 信息 页 面 
del.php 删除 价格 信息 页 面 





index.php 用 于 浏览 数据 库 内 的 记录 ， 为 detail.php 提供 附带 URL 参数 ID 的 超级 链接 ， 
便于 查看 详细 的 记录 信息 ， 如 图 3-2 所 示 。 








3-2 index.php 页 面 的 效果 
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detail.php 用 于 接受 由 index.php 传 来 的 URL 参数 ID， 利 用 URL 参数 筛选 数据 库 中 的 
记录 。 更 新 与 删除 记录 时 都 是 依靠 数据 库 中 的 主要 字段 ID 来 识别 记录 的 ， 如 图 3-3 所 示 。 








3-3 detail.php 页 面 的 效果 


当 制 作 一 个 PHP 系统 功能 时 ， 提 前 规划 网 站 的 架构 是 一 件 很 重要 的 事情 。 在 我 们 的 头 
脑 中 对 这 个 网 站 要 有 一 个 雏形 ， 如 大 概 有 哪些 页 面 、 页 面 间 的 关系 如 何等 。 


2.2 创建 数据 库 


经 过 对 前 面 功能 的 分 析 发 现 ， 数 据 库 应 该 包括 ID、 品 名 、 数 量 、 价 格 4 个 字段 。 所 以 
在 数据 库 中 必须 包含 一 个 容纳 上 述 信息 的 表 。 
接 下 来 就 要 使 用 phpMyAdmin 软件 建立 网 站 数据 库 作 为 任何 数据 查询 、 新 增 、 修 改 与 
删除 的 后 端 支持 。 
创建 数据 库 的 步骤 如 下 。 
在 下 浏览 器 地 址 栏 中 输入 “http:/127.0.0.1/phpMyAdmin/”， 在 登录 界面 输入 
MySQL 的 用 户 名 “root” 和 密码 “admin”， 如 图 3-4 所 示 。 
ED 单 击 医 梧 按钮 ， 即 可 进入 软件 的 管理 界面 ， 选 择 相关 数据 库 ， 可 看 到 数据 库 中 
的 各 表 ， 可 进行 表 、 字 段 的 增删 改 等 操作 ， 可 以 导入 、 导 出 数据 库 信 息 ， 如 图 3-5 
所 示 。 
EESRS) 单 击 归 数 据 库 按钮 ， 打 开本 地 的 “数据 库 ” 管理 界面 ， 在 “新 建 数据 库 ”文本 
框 中 输入 数据 库 的 名 称 “price”， 单 击 后 面 的 数据 库 类 型 下 拉 列 表 框 ， 在 弹出 的 
下 拉 列 表 中 选择 “utf8_general ci” 选项， 如 图 3-6 所 示 。 
3 关 注意 : ”UTF8 是 数据 库 的 编码 形式 ， 通 常 在 开发 PHP 动态 网 站 的 时 候 Dreamweaver 
默认 的 格式 就 是 UTF8 格式 , 在 创建 数据 库 的 时 候 , 也 要 保证 数据 库 储存 的 格 
式 与 网 页 调用 的 格式 一 样 ， 这 里 要 介绍 一 下 utf8_bin 和 utf8 general cid 的 区 
别 。 其 中 ci 是 case insensitive， 即 “大 小 写 不 敏感 ”， 即 a 和 A 在 字符 判断 中 


会 被 当 作 一 样 的 ; bin 代表 二 进 制 ， 所 以 utf8 bin 中 a 和 人 A 会 区 别 对 待 的 。 
EC 单 击 [要 | 按钮， 返回 “常规 设置 ”页 面 ， 在 数据 库 列表 中 就 已 经 建立 了 price 


川 氏 项 


数据 库 ， 如 图 3-7 所 示 。 


EE phpMykdain - 了 icrosoft Internet Ezplorer 
文件 EE) 编辑 于) 查看 0 收 阅 人) 工具 CD) 帮助 虽 
地 址 四 ) | 御 http: 7/127.0.0.1:800/phplyAdnin/ 


外科 些 洲 大 髓 误 汝 


+ 输入 关键 词 搜索 口 图 | 





phpMyAdmin 
欢迎 使 用 phpMyAdmin 


i 


和 于 友 


[FLanguage 
中 文 - Chinese simplified 





登录 加 





用 户 名 : 
富 码 : 














3-4 ” phpMyAdmin 的 登录 界面 





FETE TE Tp 


增 址 D) | 御 http: 1/127 0.0_1/phpayadmin/index. php?token=01231deeT5aDb99fedbeal aebebS6e64 


一 区 入 关键 司 搜索 口 加 加 593 | 高 





文件 ”编辑 下 ) 查看 YY) 收 寒 个) 工具 CD) 帮助 00 





中 localhost 


PhpMyAdmin 





_ 司 数据库 “天 SQL 。 硬 状 态 ，” 国 变量 [国字 符 集 。 装 引 列 。 的 权 限 。 上 复制 
































包 图 图 回回 局 进 程 “ 部 导出 “二 导入。 呈 同 步 
。 information_schema (17) 操作 


® mysql (17) 





全 修改 宇 码 
。 price(1) 可 如 出 


MySQL localhost 
苑 痢 建 数据 库 加 


地 
加 WysQL 连接 校对 - 
@ 


界面 


字 Language 国 
上 


图 3-5 软件 的 管理 界面 





MysQL 


加 服务 器 : localhost via TCP/IP 

加 服务 器 版 本 : 5.0.90- 
community-nt 

》 协议 版 本 : 10 

， 用 广 : root@localhost 

加 MySsQL 字符 集 : UTF-8 
Unicode (utfB) 


网 站 服务 器 
， Apache/2.0.63 (Win32) 
PHP/5.2.14 


》 MySQL 容 户 六 版 本 : 5.0.90 
》 PHP 扩展 :mysql 


phpMyAdmin 


》 版 本 信息 - 337 
加 文档 
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二 127.0.0.1 / localhost | phplyAdain 3.3.7 — Nicrosoft Internet Explorer 


地 址 四) | 御 http:/7127.0.0.1/phpmyaanin/index php?token=6333cT6el1Tc66c0039512c918b521c5 


文件 四 。 纺 得 四 查看 呈 。 收 着 内 工具 四 帮助 0 


PhpMWAdmMIn ~ locaihos 

司 数 据 库 “ 观 S0L 二 状态 ” 同 变 量 。 同 字符 蘑 。 加 引擎 。 区 权限 
介 回 回回 回 上 复制“ 志 进程 “部 导出 。 硬 导 入 了 同步 

einformation_schema (17) 章 数 据 库 


数据 库 ~ 
information_schema ”办 
mysql 中 
口 test E32 
总 计 :3 
个 _” 全 选 /全 不 选 益 四 大 图 












































3-6 新建 price 数据 库 


加 127-0.0.1:8080 / localhost | phpgyAdain 3.3-.7 - Hicrosoft Internet Explorer =] 
文件 中。 编辑 于 ) 查看 QD 收 豪 和 ) 工具 TD) 帮助 
纺 址 0) | 简 http://127 0.0_ 1:8080/pbplyAdnin/index. php?dh=pricehtaken=c2catT2fald252430311cT023e9e8458 





四 localhost 
数据 库 “型 SQL 蓝 状 态 ” 同 变 量 集 凯 引 掌 
_ 区 权限 “上 复制“ 铂 进 程 。 东 导出 古 导 入 号 同步 
。 information_schema (17) 操作 MysQL 





. 1 (17) 
a 主任 改 盏 玛 加 服务 器 -localhost via 


price 促 加 退出 TCRPIP 
加 服务 器 版 本 - 5 0 90- 


localhoat community-nt 
MSO 》 协议 版 本 : 10 


区 新 建 数据 库 加 》 用 户 ; root@localhost 
price 国 MySQL 字符 集 : UTF- 
到 向 8 Unicode (utB) 

加 MySQL 连接 校对 网 站 服务 器 


utfB_general_ci 司 @ 


Apache/20 63 
界面 (Win32) PHP/S.2.14 
， MySQL 客户 端 版 本 - 
5.0.90 


Flar 国 
= 二 = 》 PHP 扩展 - mysql 


中 文 - Chinese simplified 
二 主题 /风格 -| Onginal phpMyAdmin 
， 自 定 义 闫 色 - #2 [重要] 








Trnet 


图 3-7 创建 price 数据 库 后 的 界面 


国 于 BY 数据 库 建 立 后 ， 还 要 建立 网 页 数据 库 所 需要 的 数据 表 。 这 个 网 站 数据 库 的 数 
据 表 是 “webprice”。 建 立 数据 库 后 ， 接 着 单 击 左边 的 price 数据 库 将 其 连接 上 ， 
界面 如 图 3-8 所 示 。 








于 localhost》 匠 price 
车 结 构 “ 轩 5OL 。 亡 蕉 过 ”局 查询 其 导出 各 导 入 ” 伏 识 作 晤 权 耻 
区 到 除 


司 数据库 中 没有 表 。 









































六 铜 在 数据 库 price 中 打 汪 一 教 生 二 
| | | 


| BW 
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3-8 打开 price 数据 库 


EESe 打开 的 数据 库 右 方 界面 中 ， 有 新 建 数据 表 的 设置 区 域 ， 含 有 “名 字 ”、“ 字 
段 数 ” 两 个 文本 框 ， 在 “名 字 ” 文 本 框 中 输入 数据 表 名 称 “webprice”， 在 “字段 
数 ” 文 本 框 中 输入 本 数据 表 的 字段 数 为 “4”， 表 示 将 创建 4 个 字段 来 储存 数据 ， 
如 图 3-9 所 示 。 


加 127.0.0.1 / localhost / price | php 
地 注册 | 番 ] http:/1127.0.0.1/phpaysdaii php ?db=pricedtoken-6339c78e17c55 口 曾 回 到 庆 
文件 至) ” 编 镀 下) 查看) 收 基 人 ) 工具 XI) 帮助 如 
phpMUaAdmjn 四 localhost > price 
结构 入 
EDD Me 
数据 库 








数据 库 中 没有 表 。 


初 在 数据 库 price 中 新 建 一 个 数据 去 
字段 数 .4 








四 | 








图 3-9 输入 数据 表 名 webprice 和 字段 数 4 
再 单 击 “ 执 行 ”按钮 ， 切 换 到 数据 表 的 字段 属性 设置 界面 ， 输 入 数据 字段 名 
以 及 设置 数据 字段 的 相关 数据 ， 如 图 3-10 所 示 。 各 字段 的 意义 如 表 3-2 所 示 ( 建 议 
读者 思考 price 设置 为 varchar 的 缺点 )。 这 个 数据 表 主 要 是 记录 每 个 产品 的 基本 数 
据 和 价格 。 
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IR 





加 ncainos ， B price » webprice 





















































| 








加 时 人 天 委 在 和 中 和 入 所幸 坟 (“Wr | 也 者 单 5| 汪 "请 在 枯 轴 加 上 所 和 续 册 Weyz ors) 


et RT 
2 村 于 其 认 他 ， 计 内 久 入 车 站 ， 不 开 各 所 志 红 叶 5| 导 ， 证 前 此 交 式 : 








3-10 设置 webprice 表 各 字段 的 属性 


表 3-2 ”webprice 数据 表 


name 





ET 最 后 再 单 击 匡 梧 按钮, 切换 到 “结构 ”页 面 , 实例 将 要 使 用 的 数据 库 建立 完毕 ， 


如 图 3-11 所 示 。 








Bx-s 4)oP os 












加 acalhost 》 本 price > 目 webprice 
轩 浏 览 。 近 全 内 _ 开 SQL 上 要 索 关 新 入 作出。 后 导入 你 板 作证 洁 实习 动 中 






























































亿 男 | 加 图 回 ] 一 
ET 
和 $aql = “SELECT 。 SROM ‘webprice" LIMIT 0, 30 = 
0 sa 11 天 PHP 作风 1 关注 查询 11 人 li 
谴 并 Re 要 性 空 本 认 其 外 各 作 
司 已 ma 必 天 到 了 X 国 四 下 
EE 口 name varchar2) wn genemal 百 无 到 也 X 回 四 到 国 
口 mam tnyntd) 可 至 习 关 xx 交 各 罗 辣 
口 pice whaBg ureals 局 更 EW 
人 2 坟 12Ts 8+ 夺回 太 六 几 同 加 同 
TE] Es 
总 iiin [| | 修 名 @ 了 下 号 0 和 fk 千 之 看“ 本 [KR 
素 引 局 

















攻 1 | 个 于 5| [区] 
i 
已 用 空间 
类 于。 已 用 ba 
要 县 6 于 * 格式 0 


者 | 豆 Q iomv 





图 3-11 建立 的 数据 库 界面 


BST 为 了 页 面 制作 的 调用 需要 ， 可 以 先 在 数据 表 里 加 入 10 笔 数据 ， 在 数据 表 中 手 
工 加 入 名 为 testl ~ test10 的 10 个 测试 产品 名 ， 数 量 和 价格 也 编辑 为 不 同 的 数据 ， 
如 图 3-12 所 示 。 














G2. oo Vetonyacni /inder php?rokcnreaccszdicicdttcoceracss5coxcC A -| 9 Op 








加 localhost 加 price > 回 webprice a 
履 齐 览 “ 困 结 梅 “ 时 SQL 万 控 索 。 天 析 入 。 [ 呈 导 必 且 导入 次 旦 作 [国清 裕 网 删除 
名 星 示 和 0- 9 (10 总计 .喜光 认可 00004 各) 


















































号 相 权 [久久 各 SaL ] | 人 蛙 PHP 攻 码 ] [刷新 ] 





可 显示 ET 1 
ee 以 [办 笠 阐 恒 时 示 ， 并 月 宪 100 | 全 所 重复 标 矣 
二 由 排斥 无 





Paooocoocoaoo 
SNSSNSSANSSANS 
加 x 攻 xx 区 区 X 攻 


0 lest0 15 70 
主 丰 迁 总 中 古 。 太 XX 
| 5 fim 0 
以 [东平 便于 二 不 ， 并且 竹 100 | 行 后 重复 标 宁 


全 达 




















图 3-12 加 入 10 笔 数据 


2.3 定义 web 站 点 


在 Dreamweaver CS5.5 中 创建 一 个 价格 查询 网 站 站 点 web, 由 于 这 是 PHP 数据 库 网 站 ， 
因此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 3-3 所 示 。 


表 3-3 ”站 点 设置 的 基本 参数 

















站 点 名 称 web 

本 机 根 目录 C:\Apache\htdocs\web 

测试 服务 器 C:\Apache\htdocs\ 

网 站 测试 站 点 http://127.0.0.1/web/ 

MySQL 服务 器 地 址 C:\Apache\MySQL-5.0.90\data\price 
管理 账号 /密码 root/admin 

数据 库 名 称 webprice 


创建 web 站 点 的 具体 操作 步骤 如 下 。 
iD 在 C:\Apachehtdocs\ 路 径 下 建立 web 文件 夹 (如 图 3-13 所 示 ), 本 实例 所 有 建立 
的 网 页 文件 都 将 放 在 该 文件 夹 下 。 





了 
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EDP) 启动 Dreamweaver CS5.5， 执 行 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 
开 “ 管 理 站 点 ”对 话 框 ， 如 图 3-14 所 示 。 





各 Cc:\apache\htdocs ” 慰 | 右 | 区 | 
文件 中 编辑 EE) 查看 WW ”> 局 
@ 扫 -日 -让 PP 过 ” Er) 





地 直人 0) | 回 c:\apache\htdoe: 阐 


册 除 色 


导出 到 ) 


php phpltyAdnin 导出 


| 








3-13 ”建立 站 点 文件 夹 web 3-14 “管理 站 点 ”对 话 框 


ERS) 对 话 框 的 左边 是 站 点 列表 框 , 其 中 显示 所 有 已 经 定义 的 站 点 。 单 击 [ 融 建 四 ] 按 
钮 ， 执 行 下 拉 列 表 中 的 “站 点 ”命令 ， 打 开 “ 站 点 设置 对 象 web” 对 话 框 ， 进 行 
如 图 3-15 所 示 的 参数 设置 。 


i 


Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 文件 和 资源 的 集合 。 Dreamweaver 
站 点 通常 包含 两 个 部 分 : 可 在 其 中 存储 和 处 理 文件 
夹 ， 以 及 可 在 其 中 将 相同 文件 发 布 到 Web 上 的 服务 器 上 的 远程 文件 夹 


您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 。 


Na | 


本 地 站 点 文件 夹 : | C:Wpache\htdocs\web\ 
































3-15 ”建立 Web 站 点 


ECG) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 [ 主 ]|， 打 开 “ 基 
本 ”选项 卡 ， 进 行 如 图 3-16 所 示 的 参数 设置 。 

国 于 BY 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 界面 ， 选 中 “维护 
同步 信息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 框 中 选择 PHP MySQL 选项 (表示 
是 使 用 PHP 开发 的 网 页 )， 其 他 的 保持 默认 值 ， 如 图 3-17 所 示 。 


站 点 设置 对 旬 web 





EL RS | 
web 

:| 本地/ 网络 

C: Wpache\htdocs\ 
































http://127.0.0. 1fweb/ 
































设置 来 自 


医 得 苦痛 Web 并 发 

















3-16 “基本 ”选项 卡 的 设置 








基本 








思维 护 同步 信息 
口 保 存 时 自动 将 文件 上 传 到 服务 器 
口 启用 文件 取出 功能 
避 打开 文件 之 前 职 出 
职 出 名 称 ; 


电子 邮件 地 址 : 上 


测试 服务 器 
服务 器 模型: 



































帮助 


























] | 设置 来 自 


医 汪 其 形 Web 玫 发 




















图 3-17 设置 “高 级 ”选项 卡 








川 氏 匡 


守 友 加 型 特 准 淋 本 四 恬 续 


EECSRD 单 寺 全 本 | 按钮 ,返回 “服务 器 ”设置 界面 选中 “测试 ” 复 选 框 ， 如 


图 3-18 所 示 。 





EE 单 击 [ 保 奉 ”| 按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CS5.5 中 就 
有 了 刚才 所 设置 的 站 点 web。 单 击 [守成 名 按钮， 关闭 “管理 站 点 ”对 话 框 这样 
就 完成 了 Dreamweaver CS5.5 测试 web 站 点 的 网 站 环境 设置 。 
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站 点 设置 对 象 web 





您 将 在 此 位 置 选择 尖 载 Web i 此 对 话 框 的 设置 来 自 
Internet 服务 提供 商 (ISP) 或 Web 管理 员 


些 语 : 要 下 申 素 Dreamweaver 好 点 上 工作 ， 佐 五 南 写 成 几 步 需 ， 基 办 要 攻关 姑 Web 并 发 
布 页 而 ， 低 只 请 它 义 一 个 远 咖 及 务 如 8 可 - 





名 称 | 地址 | 连接 | 远程 测试 | 
web C/Apache/htdocs/ 本 地 /网 络 世 [el 
































图 3-18 设置 “服务 器 ”参数 
2.4 ”建立 数据 库 连接 

完成 了 站 点 的 定义 后 ， 需 要 将 网 站 与 前 面 的 price 数据 库 建立 连接 。 网 站 与 数据 库 的 连 
接 步骤 如 下 。 


EEC 执行 “文件 ”一 “新 建 ” 命 令 ， 在 网 站 根 目录 下 新 建 一 个 空白 HIML 文档 ， 
输入 网 页 标题 “价格 查询 ”， 保 存 为 ndex.php， 如 图 3-19 所 示 。 


[DW XH M0) ED AC NAD WE) HFC) MSG) NO Mm) | 








ETMe c= 





去 要 在 省 面 上 全 用 把 才 数 据 : 
1 。 请 为 文件 划 奸 一 个 站 点 ， 
2 连 拉 一 和 


3 设 下 点 区 到 二， 























图 3-19 创建 空白 网 页 
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国 T2Y 执行 “窗口 ”一 “数据 库 ” 菜 单 命令 ， 打 开 “ 数 据 库 ” 面板 。 在 “数据 库 ” 面 
板 中 单 击 国 图 标 ， 并 在 打开 的 菜单 中 选择 “MySQL 连接 ”选项 ， 如 图 3-20 所 示 。 


连接 下 
1. 为 该 文件 创建 站 点 。 
2. 选择 一 种 文档 类 型 。 


3， 设置 站 点 的 测 这 服务 器 。 
4. 单 击 上 面 的 + 按钮 创建 连接 。 


生 克 器 型 特 叭 淋 蕊 四 蜂 纪 ”II 绪 基 





图 3-20 选择 “MySQL 连接 ” 

ERe 在 “MySQL 连接 ”对 话 框 中 ， 输 入 连接 名 称 为 “webconn”，MySQL 服务 器 
名 为 “localhost”， 用 户 名 为 “root”， 密 码 为 “admin”。 选 择 所 要 建立 连接 的 数 
据 库 名 称 ， 可 以 单 击 [三 到] 按钮 浏览 MySQL 服务 器 上 的 所 有 数据 库 。 选 择 刚 导 
入 的 范例 数据 库 “price”， 具 体 的 设置 内 容 如 图 3-21 所 示 。 


: webcorm 





[localhost 





root 








3 





: price 








3-21 设置 MySQL 连接 参数 


EEC 单 击 [ 琵 ] 按 钮 测试 与 MySQL 数据 库 的 连接 是 否 正确 ， 如 果 正 确 ， 则 弹出 
一 个 提示 消息 框 ， 如 图 3-22 所 示 ， 这 表示 数据 库 连 接 已 设置 成 功 。 




















图 3-22 设置 成 功 


PHP+MysaL 
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单 击 C 胡 E_] 按 钮 ， 则 返回 编辑 页 面 ， 在“ 数据库 ”面板 中 显示 绑 定 过 来 的 数据 库 ， 如 
图 3-23 所 示 。 
在 建立 完成 MySQL 连接 后 ， 在 “文件 ”面板 中 会 看 到 Dreamweaver 自动 建立 了 
Connections 文件 夹 ， 在 该 文件 夹 下 有 一 个 与 前 面 所 建立 的 MySQL 连接 名 称 相同 的 文件 ， 
如 图 3-24 所 示 。 




















日 国 webeonn 


ZI (int 11 必需 的 ) 
name (varchar 20 必 有 
nom (tinyint 4 必需 | 





price (varchar 20 必 击 
田 - 间 视图 二 detail.php IKB PHP 
久 ”预存 过 程 司 inaex. php SKB FHP 
二 update. php SKB Pi 
3-23 ” 绑 定 的 数据 库 3-24 ”自动 生成 的 webconn.php 文件 


Connections 文件 夹 是 Dreamweaver 用 来 存放 MySQL 连接 设置 文件 的 文件 夹 。 打 开 该 
文件 夹 并 使 用 “代码 ”视图 ， 可 以 看 到 有 关连 接 数 据 库 的 设置 ， 如 图 3-25 所 示 。 


DW 文件 ”编辑 (D 查看 WD 插入 (D 修改 人 格式 (0) 命令 站 点 (3) 侠 吕 帮助 吧 | | Wt ” [ETGEE 滞 
| [两 ] 折 分 设计 | 实时 代码 | 户 X 实时 视图 检查 名. 二、 标题: 

























































"| 
PE 
w le pe 
| ，= [TI | 
千 5 bi i = "localhost"; 了 ”ID Gnt il 必需 的 ) 
ee $database_ webconn - "price": BD nne (varchar 20 好 | 
品目 让 usernane webconn - “rooc: Mn ar 
a passvord webconn = "12345-; hp 
国明 swebconn = mysql_pconnect (shostnane webconn, $username vebconn, $passvword_ webconn) 由 浊 视图 
wn or trigger_error (mysql_error(),E_USER ERROR); 入 预 丰 过 程 
全 200 ?> 区 
一 | 加 
四 | | 二 
回 [EY 品 EEE9 ~ 
国 = 
区 | 
只 
[ee] | 
Ed | 
¥ 
1FK/1 Unicode OTF-8) 
EE TE al 
[yxmu] | 格式 四 | 无 YY 类 | 无 v B71 二 生姜 超标 Di | 
好 cs | nDEFE “| 几 册 S| 

















图 3-25 数据库 连接 设置 


在 这 个 文件 中 定义 了 与 MySQL 服务 器 的 连接 (mysql pconnect 函数 )， 包 括 以 下 参数 。 
@ ”$hostname webconn: MySQL 服务 器 的 地 址 。 
@ S$database webconn: 连接 数据 库 的 名 称 。 
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@  $userame webconn: 用 户 名 称 。 

@ Spassword webconn: 用 户 密码 。 

定义 的 值 与 我 们 前 面 在 图 形 界面 所 设置 的 是 对 应 的 ， 然 后 利用 函数 mysql pconnect 与 
数据 库 连 接 。 连 接 后 才能 对 数据 库 进行 查询 、 新 增 、 修 改 或 删除 的 操作 。 

在 网 站 制作 完成 后 ， 将 文件 上 传 至 网 络 上 的 主机 空间 时 ， 如 果 发 现 网 络 上 的 MySQL 服 
务 器 访问 的 用 户 名 、 密 码 等 方面 与 本 机 设置 有 所 不 同 ， 可 以 直接 修改 位 于 Connection 文件 
夹 下 的 webconn.php 文件 。 


3 | 动态 服务 器 的 行为 


和 于 友 慎 型 特 瞪 淋 号 轩 景 续 ”1|| 红 项 











3.1 创建 新 记录 集 


在 每 个 需要 查看 数据 库 记 录 的 页 面 中 ， 都 应 为 其 建立 一 个 “记录 集 ( 查 询 )”， 从 而 可 以 
让 Dreamweaver 知道 ， 目 前 这 个 网 页 中 所 需要 的 是 数据 库 中 的 哪些 数据 。 即 便 需 要 的 内 容 
一 样 ， 在 不 同 的 网 页 中 也 需要 单独 建立 。 同 一 个 数据 库 只 须 建立 一 次 MySQL 连接 , 但 我 们 
可 为 同一 个 MySQL 数据 库 连 接 建 立 多 个 “记录 集 ”， 配 合 筛选 的 功能 ， 实 现 某 个 记录 集 只 
包含 数据 库 中 符合 某 些 条 件 的 记录 。 
打开 index.php 文件 后 ， 从 菜单 栏 中 选择 “窗口 ”一 “ 绑 定 ” 命 令 ， 打 开 “ 绑 定 ”面板 ， 
选择 “记录 集 (查询 )” 便 可 以 建立 记录 集 。“ 绑 定 ”面板 中 的 “记录 集 (查询 )” 与 “服务 器 
行为 ”面板 中 的 “记录 集 ” 是 相同 的 ， 如 图 3-26 所 示 。 
3 | 服务 器 生 为 | 三] 


国 一 文档 类 型: PP 

















图 3-26 ”选择 “记录 和 集 (查询 )” 


按说 明 设 置 各 项 字段 (如 图 3-27 所 示 ), 然后 单 击 [_ 测 * _] 按 钮 ， Dreamweaver 会 显示 目 
前 设置 所 返回 的 记录 和 集 内 的 所 有 记录 ， 字 段 的 功能 说 明 如 表 3-4 所 示 。 
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名 称 : [rsdl 
连接 : webcomn 司 | [定义 .. 
表格 : > 

列 : 人 @ 全 部 。 〇 选 定 的 : 

















3-27 ”设置 记录 集 


表 3-4 字段 与 功能 说 明 


字 段 说 明 
名 称 一 般 用 Recordset( 记 录 集 ) 的 缩写 rs 作为 开头 
连接 选择 所 建立 的 数据 库 是 哪个 MySQL 连接 
列 此 处 显示 该 数据 库 连 接 中 所 有 的 数据 表 ， 以 及 所 筛选 数据 表 内 的 所 有 字段 
筛选 是 否 依据 条 件 筛选 记录 
排序 是 否 依照 某 个 字段 值 排序 。 例 如 ， 在 新 闻 系 统 中 ， 需 要 把 新 的 新 闻 放 到 前 面 位 置 ， 就 





可 以 使 用 排序 的 功能 


记录 集 使 用 到 的 就 是 SELECT 语句 ， 因 为 查 出 来 的 结果 有 可 能 会 有 很 多 条 ， 所 以 称 为 


记录 集 ( 合 )， 而 “筛选 ”部 分 则 对 应 WHERE 子 句 。 
单 击 [__ 到 _] 按 钮 后 ， 可 以 看 到 返回 的 记录 。 因 为 没有 任何 筛选 的 处 理 ， 所 以 会 返回 完 


整 的 所 有 记录 ， 如 图 3-28 所 示 。 


测试 59L 指 令 














test10 








图 3-28 单 击 “ 测 试 ”按钮 浏览 记录 集 


可 以 单 击 [L 才 .按钮 查看 SQL 语句 。 可 以 看 到 ，Dreamweaver 提供 了 一 个 基本 的 图 
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形 界 面 ， 实 际 上 它 会 生成 相应 的 程序 代码 。 在 高 级 窗口 中 可 以 看 到 相应 的 SQL 语句 ， 另 外 ， 
还 提供 了 加 入 变量 、 修 改 SQL 语句 的 功能 ， 用 以 满足 使 用 简单 图 形 界面 设置 无 法 满足 的 情 
况 ， 如 图 3-29 所 示 。 











生 克 器 弄 特 叭 淋 蕊 四 蜂 纪 ”|| 绪 匡 






































图 3-29 ”高 级 记录 集 窗口 
在 记录 集 建立 完毕 后 ， 我 们 可 以 从 应 用 程序 的 “ 绑 定 ”面板 中 查看 到 目前 页 面 里 的 所 
有 记录 集 ， 以 及 各 种 记录 集中 的 字段 。 
双击 记录 集 ， 可 以 重新 打开 如 图 3-30 所 示 的 设置 窗口 。 














图 3-30 ” 绑 定 的 记录 集 效 果 


建立 记录 集 与 直接 写 SELECT 语句 是 相同 的 ， 将 页 面 切换 到 “代码 ”视图 ， 如 图 3-31 
所 示 。 其 中 第 1 行 的 require_once 函数 是 用 来 引入 文件 的 ， 即 前 面 介绍 的 webconn.php。 在 
Dreamweaver 中 ， 若是 我 们 已 经 定义 好 数据 库 连接 ， 那 么 在 其 他 建立 记录 集 、 更 新 记录 、 插 
入 记录 、 删 除 记录 的 页 面 中 ， 这 个 连接 设置 文件 就 会 在 页 面 的 最 前 面 被 引入 (这 就 是 为 什么 
在 同一 个 站 点 中 只 需要 定义 一 次 MySQL 数据 库 连 接 )， 因 为 该 文件 中 所 包括 的 与 数据 库 连 
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接 相 关 的 设置 需要 被 使 用 。 








if (lfunction exists ("GetSQLYal eString") 
funetion GetSLValueSt 


StheValue = get_aagi 





32 mysql_select_db($database_webconn, $webconn); 
33 $query_rsdb = "SELECT * FROM webprice"; 





34 Srsdb = mysql_query($query_rsdb, $webconn) or die(mysql_error()); 
35 $row_rsdb = mysql_fetch_assoc($rsdb); 
36 S$totalRows_rsdb = mysql_num_rows($rsdb); 


3-31 自动 生成 的 代码 


其 程序 具体 分 析 如 下 。 

(1) 第 32 行 引用 了 webconn.php 内 的 设置 (变量 $database_webconn 与 Swebconn 都 被 定 
义 在 这 个 文件 中 ) 来 选择 数据 库 (mysql_select_db())， 随 后 的 mysql_query0 所 作用 的 都 是 此 数 
据 库 。 

(2) 第 33 行 定义 了 查询 数据 库 的 SQL 语句 。 

(3) 第 34 行使 用 33 行 所 定义 的 SQL 语句 对 数据 库 执行 查询 操作 (mysql_query0)， 此 
时 ， 返 回 结果 是 资源 标识 符 ， 还 不 能 被 使 用 。 

(4) 第 35 行将 前 面 检查 的 结果 以 关系 型 数组 形式 (mysql_ fetch_assoc()) 传 至 变量 $row_ 
rsdb， 然 后 就 可 以 使 用 $row_ 记 录 和 集 名 称 [“ 字 段 名 称 ] 来 取得 记录 和 集 字 段 值 。 

(5) 第 36 行 取得 查询 结果 的 记录 条 数 (mysql num rows0) 并 赋 给 变量 $totalRows_rsdb。 

(6) 最 后 mysql free_result() 释 放 查 询 结果 与 占用 的 内 存 资源 。 

上 面 是 Dreamweaver 连接 数据 库 并 执行 查询 的 标准 步骤 ， 在 mysql_query($query_rsdb， 
$webconn) or die(mysql_errorO) 的 部 分 , 若 or 前 面 的 语句 错误 或 失败 ,就 执行 or 后 面 的 程序 。 
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互 





所 以 若 数 据 库 查询 失败 的 时 候 ， 就 会 产生 错误 信息 ， 并 终止 程序 的 运行 。 
在 一 般 PHP 程序 中 ， 典 型 的 连接 与 查询 程序 类 似 下 面 的 例子 : 


Mysql select db ($dqatabase webconn，S$webconn) 7 

$query rsdb = "SELECT * FROM webprice"; 

$rsdb = mysql query($query rsdb, $webconn) or die (mysql error()); 
$row rsdb = mysql fetch assoc($rsdn); 

$totalRows rsdb = mysql num rows($rsdb); 

Mysql free result (rsdb); 


和 于 友 慎 型 特 瞪 淋 号 团 品 续 ”11MI| 红 项 


读者 可 能 会 觉得 Dreamweaver 产生 出 来 的 程序 代码 比较 复杂 ， 这 是 因为 Dreamweaver 
建立 的 记录 集 需要 搭配 很 多 服务 器 行为 来 使 用 。 


3.2 ”显示 记录 功能 


要 将 记录 集 内 的 记录 ( 即 数据 库 中 的 数据 ) 直 接 显示 到 网 页 上 ， 实 现 的 步骤 如 下 。 

ES 在 “文件 ”面板 中 打开 index.php， 在 网 页 中 制作 一 个 如 图 3-32 所 示 的 2x4 表 
格 ， 表 格 宽度 600 像素 ， 边 框 粗细 2 像素 ， 然 后 在 “ 绑 定 ”面板 上 分 别 选择 记录 
集中 的 字段 ， 并 拖 动 到 表格 的 相应 单元 格 中 。 
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图 3-32 绑 定 字段 


在 使 用 鼠标 拖 动 字段 至 页 面 上 放 开 后 ， 会 出 现 如 {rsdb.ID} 的 字样 ， 其 中 rsdb 为 记录 集 
名 称 ，ID 为 字段 名 称 。 将 产品 编号 、 产 品名 称 、 产 品 数量 、 产 品 价格 4 个 字段 依次 分 别 拖 
至 相应 的 单元 格 ， 然 后 单 击 上 E 莹 时 疗 图 按钮 。 

视图 所 呈现 的 效果 与 使 用 浏览 器 打开 网 页 一 样 ， 原 本 仅 显示 { 记 录 集 名 称 .字段 名 称 } 的 
部 分 将 会 显示 出 记录 集 内 的 记录 ， 如 图 3-33 所 示 。 
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图 3-33 ”实时 视图 的 效果 


再 单 击 一 次 | 实时 视图 | 按钮 ， 将 页 面 切换 到 “代码 ”视图 。 我 们 来 看 看 {记录 和 集 
名 称 .字段 名 称 } 部 分 的 代码 ， 可 以 看 到 ， 程 序 代码 中 使 用 echo 来 输出 字段 值 ， 如 
图 3-34 所 示 。 
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图 3-34 ”代码 视图 的 效果 


3.3 ”重复 区 域 功能 


在 只 能 看 到 记录 集中 的 第 1 条 记录 ， 那 后 面 的 记录 怎么 显示 出 来 呢 ?Dreamweaver 
提供 了 “重复 区 域 ”及 “记录 集 分 页 ”的 功能 ， 只 要 以 鼠标 拖 动 ， 就 可 以 实现 这 个 功能 。 
选取 需要 重复 的 部 分 ， 即 表格 中 的 第 2 行 ， 如 图 3-35 所 示 ， 然 后 在 “服务 器 行为 ” 
面板 中 单 击 “ 添 加 服务 器 行为 ”按钮 [ 蔬 ， 从 弹出 的 下 拉 菜单 中 选择 “重复 区 域 ”命令 ， 
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如 图 3-36 所 示 。 
结果 查询 系统 
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3-35 ”选取 表格 的 第 2 行 


as 1 ES| 
十 一 ”文档 类 型 : PHP 
| “记录 集 
记录 和 集 分 页 » 
显示 区 域 » 
显示 记录 计数 上 
动态 文本 


插入 记录 

更 新 记录 

删除 记录 

动态 表单 元 素 » 
用 户 身份 验证 » 
XSLT 转换 

编辑 服务 器 行为 ... 

新 建 服务 器 行为 . .. 

获 职 更 多 服务 器 行为 .. 























图 3-36 ”选择 “重复 区 域 ”命令 


应 该 确认 选取 的 标签 为 <tr>, 因为 重复 区 域 会 使 用 do…while 循环 来 包围 所 作用 的 范围 。 
而 需要 重复 的 仅 是 第 2 行 的 表格 ， 在 HTML 中 ， 表 格 的 行 是 使 用 <tr> 标 签 。 确 认 选 取 的 标 
签 正确 ， 执 行 时 才 不 会 发 生 错误 。 

此 时 会 弹出 “重复 区 域 ” 对话 框 ， 如 图 3-37 所 示 ， 要 求 我 们 选择 要 重复 记录 的 记录 集 ， 
以 及 需要 重复 几 条 记录 或 显示 全 部 记录 。 














图 3-37 设置 重复 区 域 


字 友 里 型 特 叭 济世 四 蜂 纪 ”|| 绪 匡 
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单 击 [ 砍 E ] 按 钮 后 ， 同 样 地 选择 | 实时 视图 | 按钮， 这 时 就 可 以 看 到 原来 只 有 两 行 的 表 
格 已 经 增长 到 6 行 ， 如 图 3-38 所 示 ， 而 记录 集 内 的 前 5 条 都 显示 在 页 面 上 了 。 
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图 3-38 ”实时 效果 预览 
所 有 页 面 上 的 “服务 器 行为 ”都 会 被 列 在 “窗口 ”一 “服务 器 行为 ”面板 的 清单 中 ， 
如 图 3-39 所 示 。 在 本 例 中 ， 我 们 选择 重复 5 条 记录 。 若 要 修改 重复 记录 的 设置 ， 双 击 服务 
器 行为 清单 中 的 “重复 区 域 ” 即 可 。 





口 ] 文档 类 型 : PP 
Recordset (rsdb) 
重复 区 域 (rsdb) 
动态 文本 (rsdb. ID) 
动态 文本 (rsdb. name) 
动态 文本 (rsdb. num) 
动态 文本 (rsdb. price) 















图 3-39 “服务 器 行为 ”面板 


将 页 面 切换 到 “代码 ”视图 ， 可 以 看 到 ， 在 套用 了 “重复 区 域 ” 服 务 器 行为 后 ， 在 程 
序 代码 中 的 变化 便 是 这 行 单元 格 的 上 下 被 do...while 循环 包围 了 ， 而 重复 的 条 件 为 第 94 行 
语句 ( 见 图 3-40)， 用 这 样 的 循环 可 以 实现 将 记录 集中 的 记录 全 部 输出 才 停止 循环 。 

在 建立 记录 集 时 ， 我 们 就 知道 有 10 条 记录 都 在 记录 集中 ， 可 是 在 这 里 怎么 显示 了 5 条 
记录 呢 ? 回头 来 检查 一 下 代码 ， 如 图 3-41 所 示 。 
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3-40 ”循环 语句 
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3-41 代码 窗口 


人 在 第 42 行 变 量 Squery_rsdb 所 用 的 SQL 语句 是 以 前 介 
绍 过 的 ， 但 在 第 43 行 ， 该 变量 会 放 到 字符 串 的 第 一 个 %s 位 置 处 : 


$query limit rsdb = 
sprintf ("%s LIMIT %d, sd", $query rsdb, $startRow rsdb, $maxRows rsdb); 


由 上 述 代码 可 知 ，%s 表示 字符 串 ， 后 面 两 个 %d 表示 数值 ， 所 要 代入 的 值 是 $startRow 
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与 SmaxRows rsdb。 而 SmaxRows_rsdb 变量 值 与 我 们 前 面 在 重复 区 域 所 选择 的 重复 5 条 记录 
是 同步 的 ， 即 第 32 行 自动 定义 了 这 个 变量 的 值 : 


SmaxRows rsdb = 5; 


可 以 知道 , Dreamweaver 使 用 了 一 堆 变 量 来 记录 在 图 形 界面 中 所 选择 和 设置 的 值 , 然后 
使 用 LIMIT 子 句 来 实现 一 次 显示 指定 条 数 的 记录 。 


3.4 记录 集 的 分 页 


前 面 我 们 已 经 可 以 浏览 记录 集中 的 第 1 ~ 5 条 记录 了 ， 那 剩 下 的 记录 如 何 显示 出 来 呢 ? 
下 面 就 介绍 记录 集 分 页 功能 的 实现 方法 。 
EC 在 页 面 下 方 加 上 1x4 的 表格 ， 参 数 与 上 方 表格 相同 。 接 着 在 单元 格 中 分 别 输 
入 “[ 第 一 页 ]”、“[ 上 一 页 ]”、“[ 下 一 页 ]”、“[ 最 后 一 页 ]” 的 文字 ， 使 用 鼠标 
选取 “[ 第 一 页 ]”， 然 后 在 “服务 器 行为 ”面板 中 单 击 [ 鸭 ] 按 钮 ， 从 弹出 的 下 拉 菜 
单 中 选择 “记录 集 分 页 ”一 “ 移 至 第 一 页 ”命令 ， 如 图 3-42 所 示 。 
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图 3-42 设置 为 “ 移 至 第 一 页 ” 


在 弹出 的 对 话 框 中 选择 记录 集 ， 以 及 确认 链接 所 选 的 范围 ， 如 图 3-43 所 示 。 

ES 分 别 为 [上 一 页 ]、[ 下 一 页 ]、[ 最 后 一 页 ] 套 用 “ 移 至 上 一 页 ”、“ 移 至 下 一 页 ”、 
“ 移 至 最 后 一 页 ”的 服务 器 行为 。 然 后 按键 盘 上 F12 键 ， 在 浏览 器 中 检查 输出 结 
果 ， 如 图 3-44 所 示 。 在 页 面 中 测试 刚刚 完成 的 导航 条 ， 可 以 看 到 网 址 后 面 加 了 
pageNum dbrs 与 totalRows_dbrs 两 个 URL 变量 , 它们 被 用 来 在 分 页 浏览 时 与 重复 
区 域 服务 器 行为 相 搭配 。 
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图 3-43 设置 为 “ 移 至 第 一 页 ” 
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3-44 ”分 页 浏览 效果 





生 友 器 弄 特 哈 济世 四 蜂 纪 ”|| 绪 匡 


也 可 以 在 Dreamweaver 菜单 栏 中 执行 “插入 ”一 “数据 对 象 ” 一 “记录 集 分 页 ”一 “ 记 


录 集 导航 条 ”命令 ， 来 快速 地 插入 本 范例 中 所 建立 的 记录 集 导 航 条 。 


3.5 ”显示 记录 个 数 


在 页 面 上 方 分 别 输入 “共有 * 笔 记录 ， 目 前 查看 第 * 笔 至 第 * 笔 ”， 建 立 起 记录 集 导 航 条 ， 


以 便 让 用 户 了 解 有 多 少 页 记录 ， 当 前 正在 浏览 第 几 页 。 


ED 将 插入 点 置 于 “共有 ”和 “笔记 录 ” 之 间 ， 单 击 “ 服 务 器 行为 ”面板 中 的 鸭 按 
钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “显示 记录 个 数 ” 一 “显示 总 记录 数 ”选项 ， 在 对 


话 框 中 选择 记录 和 集 ， 单 击 [_ 右 按钮 ， 如 图 3-45 所 示 。 


国 于 2Y 按 上 述 方法 ， 分 别 在 相应 位 置 依次 加 入 “显示 起 始 记录 编号 ”及 “显示 结束 
记录 编号 ”行为 ， 完 成 后 的 页 面 如 图 3-46 所 示 。 
完成 后 ， 当 我 们 浏览 该 网 页 时 ， 便 会 出 现 “ 共 有 和 笔记 录 ， 目 前 查看 第 Y 笔 至 第 Z 笔 ” 


的 提示 文字 ， 如 图 3-47 所 示 。 


也 可 以 在 Dreamweaver 菜单 中 执行 “插入 ”一 “数据 对 象 ”一 “显示 记录 集 数 ”一 “ 记 


录 集 导航 条 ”命令 来 快速 地 插入 本 例 中 所 要 建立 的 记录 集 导 航 条 。 
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3-45 ”显示 总 记录 数 
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共有 10 笔记 录 ， 目 前 查看 第 6 笔 至 第 10 笔 
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3-47 ”建立 导航 条 效果 





3.6 ”显示 区 域 功能 


如 果 打 开 的 是 首页 ， 那 么 [第 一 页 ] 与 [上 一 页 ] 的 文字 链接 是 没有 意义 的 。 下 面 就 来 处 理 
这 个 问题 ， 当 不 是 第 一 页 时 ， 显 示 [ 第 一 页 ] 和 [上 一 页 ]。 当 不 是 最 后 一 页 时 ， 显 示 [ 下 一 页 ] 
和 [最 后 一 页 ]。 
实现 的 步骤 如 下 。 
ESD 选择 “[ 第 一 页 ]”， 在 “服务 器 行为 ”面板 中 单 击 [ 国 按 钮 ， 从 弹出 的 下 拉 菜 单 
中 选择 “显示 区 域 ”一 “如 果 不 是 第 一 页 则 显示 ”选项 , 如 图 3-48 所 示 ， 弹 出 “如 
果 不 是 第 一 页 则 显示 ”对 话 框 , 选择 记录 集 为 rsdb, 单 击 [ 确 E ] 按 钮 .然后 为 <[ 上 
一 页 ]” 也 做 同样 的 设置 。 
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图 3-48 选择 “如 果 不 是 第 一 页 则 显示 ”选项 
ED) 选取 “[ 下 一 页 ]” 链 接 文字 ， 在 “服务 器 行为 ”面板 中 单 击 罗 按钮， 从 弹出 的 
下 拉 菜单 中 选择 “显示 区 域 ”一 “如 果 不 是 最 后 一 页 则 显示 ”选项 ， 如 图 3-49 所 
示 ， 弹 出 “如 果 不 是 最 后 一 页 则 显示 ”对 话 框 ， 选 择 记录 集 为 rsdb， 单 击 王 十 
按钮 。 最 后 为 “[ 最 后 一 页 ]” 也 做 同样 的 设置 。 
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图 3-49 设置 “如 果 不 是 最 后 一 页 则 显示 ” 


ES 完成 后 ， 在 每 个 套用 “显示 区 域 ”服务 器 行为 的 部 分 会 出 现 “ 如 果 符 合 此 条 
件 则 显示 ”的 提示 文字 ， 如 图 3-50 所 示 。 
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3-50 ”套用 显示 区 域 的 效果 


最 后 ， 按 下 F12 键 ， 在 浏览 器 中 检查 输出 结果 ， 如 图 3-51 所 示 。 
涉 注意 : ”也 可 以 在 Dreamweaver 菜单 栏 中 选择 “插入 ”一 “数据 对 象 ”一 “记录 对 象 ” 
一 “记录 集 (Recordseb 分 页 ”一 “记录 集 导 航 条 ”命令 ， 来 快速 地 插入 一 个 分 
页 区 域 。 
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EE 价格 查询 - 了 Hicrosoft Internet Ezplorer 
文件 下) 编辑) 查看 G) 收 送 和 工具 CD) 帮助 0 
地 址 四) | 逢 http://127.0.0. 1/web/index. php?pageNun_rsd1=1&totalRows_rsd=10 











价格 查询 系统 





共有 10 条 记录 ， 目 前 查看 第 6 笔记 录 至 第 10 笔 记录 。 
产品 价格 
6 











节 友 器 弄 特 哈 济世 四 蜂 纪 ”|| 红 二 























3-51 设置 显示 区 域 后 的 效果 


3.7 ”显示 详细 信息 


通常 ， 一 个 动态 网 站 的 数据 量 是 很 大 的 ， 在 很 多 时 候 并 不 会 一 开始 就 将 数据 库 所 有 字 
段 、 记 录 都 显示 出 来 。 
例如 一 个 新 闻 系 统 ， 在 首页 只 会 显示 新 闻 的 日 期 与 标题 ， 更 详细 的 新 闻 内 容 需 要 选择 
标题 后 进入 到 另 一 个 页 面 才能 显示 。 
假设 显示 新 闻 标 题 的 页 面 是 index.php， 而 显示 详细 新 闻 内 容 的 网 页 名 称 为 detail.php。 
当 在 index.php 中 单 击 标题 的 链接 后 ， 此 时 ， 该 超 链接 会 带 着 一 个 参数 到 detail. php， 网 址 类 
似 于 “detailphp?ID=1”。 多 出 的 “ID=1” 是 一 个 变量 名 为 ID、 值 为 1 的 URL 参数 ， 并 将 
记录 详细 信息 显示 在 网 页 上 。 这 样 就 构成 了 一 个 简单 的 新 闻 系 统 架构 。 
要 筛选 指定 的 记录 ， 可 以 在 SQL 中 使 用 WHERE 子 句 ， 在 Dreamweaver 中 有 相应 的 图 
形 界面 ， 可 以 方便 使 用 。 下 面 我 们 来 看 看 Dreamweaver 是 如 何 通 过 传送 与 接收 URL 参数 来 
筛选 出 指定 记录 的 。 
El 使 用 Dreamweaver 创建 一 个 空白 detail.php 页 面 并 保存 。index.php 中 筛选 要 用 
来 连接 到 详细 信息 页 面 的 部 分 (其 实 就 是 选择 要 在 哪里 建立 超 链接 ), 在 本 例 中 ， 选 
择 编号 ， 即 选择 {rsdb.ID} 动 态 文字 ， 如 图 3-52 所 示 。 
EECSRDD 在 下 面 的 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 览 文件 ”图 标 回 | 
如 图 3-53 所 示 。 
在 弹出 的 对 话 框 中 , 选择 用 来 显示 详细 记录 信息 的 页 面 detail.php, 如 图 3-54 
所 示 。 
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结果 查询 系统 


和 笔记 好， 且 前 查看 第 je 和 FrstReroedy 竿 平 第 freahTastRerord 笔 


条 
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怒 css wD 无 链接) YG@ 书 。 睹 @ 

















口 六 ”要 四 于 ”~| 识 如 | ”| 标题 加 口 








3-53 ”建立 链接 的 设置 


站 点 和 服务 器 


查找 范围 QD: | 已) web 站 日 侍 书 加 
已 -mserverscripts 国 E@ 于 于 


回 inaexl. php 
上 回 index. php 
加 mpdate php 


选择 文件 名 自 : @) 文件 系统 
数据 源 














文才 各 加 ED 
文件 类 型 CD): | 所 有 文件 (+.*) 


























YRL: /web/ detail. php 
相对 于 : | 站 点 根 目录 | /web 
在 站 点 定义 中 更 改 默 认 的 链接 相对 于 








3-54 ”设置 链接 的 文件 


EEC 如 果 只 是 这 样 ， 那 只 会 是 单纯 的 超级 链接 ， 并 没有 附带 URL 参数 ， 因 此 ， 要 
单 击 Cs 要 按钮。 设置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 。 本 例 将 参数 名 
称 命名 为 ID， 在 设置 值 的 时 候 ， 单 击 图 3-55 文本 框 右边 的 图 标 贺 。 

选择 URL 参数 ID 所 要 带 的 值 ， 因 为 我 们 要 的 是 记录 集 ID 字段 的 值 ， 所 以 选 
择 D 字段 ， 如 图 3-56 所 示 ， 然 后 单 击 忆 副 E_] 按 钮 。 除 了 记录 集 字段 外 ， 只 要 是 
在 “ 绑 定 ” 面 板 中 所 建立 的 ， 包 括 表单 变量 、URL 变量 、Session 变量 和 Cookie 
变量 等 ， 都 可 以 在 这 里 被 选择 。 






































图 3-55 设置 参数 


字 友 里 型 特 叭 淋 蕊 四 蜂 纪 ”|| 导 大 





格式 : 无 、 
代码 : | 人 php echo Srow_rsdb[' ID]: ?> | | 





3-56 选择 ID 字段 
E53 超级 链接 的 地 址 变 成 了 “detailphp?ID=<?php echo $row_rsdb[TID7]; ?>”， 如 

















图 3-57 所 示 。 
属性 
《HL 格式 四 | 无 ~| 类 于 vB7 汪 生 二 二 村 WD [ | 
肛 css DD | 无 司 独 芒 加 Pphp echo $rowrsdb['ID]; ?回国 加 目标 @ -本 
中 | 单元 格 。 水平 四 | 黑人 四 | 宽 加 ] 不 换行 @) 口 ” 青 最 颜色 (G) 厂 -| | [CRGRE | 
= 站 二 DIK ”| 高] 村 是 名 

















3-57 ”完成 后 的 链接 地 址 


设置 完成 后 ， 可 以 用 浏览 器 打开 index 页 面 。 在 正 底部 的 状态 栏 中 可 以 看 到 
每 一 条 记录 的 链接 都 带 着 URL 参数 ID， 其 值 是 每 条 记录 的 ID， 如 图 3-58 所 示 。 
前 面 已 经 完成 了 index.php 页 面 的 制作 ， 下 面 来 设计 接收 URL 参数 的 detail.php 页 面 ， 
看 看 如 何 用 收 到 的 参数 来 筛选 指定 的 记录 。 
新 建 detaiLphp 文档 ， 设 计 页 面 ， 插 入 2x5 表格 ， 宽 度 为 750 像素 ， 然 后 选择 
“ 绑 定 ”面板 ， 单 击 [而 | 按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “记录 集 ( 查 询 )” 选 项 ， 
如 图 3-59 所 示 。 
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PHP+MySQL 
动态 网 站 设计 恨 用 教程 
到 价格 查询 系统 - 了 crosoft Internet Explorer 


文件 @) 编辑 下 ) 查看 如 收 豪 和 ) 工具 XI) 帮助 加 
地 址 @@) | 秋 http://127.0.0.1:8080/web/indexl. php?paseJun_rsd=1atotalRows_rsdl=10 二 输入 关键 辣 搜索 口 司 


价格 查询 系统 上 











共有 10 笔 记录 ， 目 前 查看 第 笔记 录 至 第 8 笔记 录 
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图 3-59 选择 “记录 集 (查询 )” 


ES 在 打开 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 : 

e@ 在“ 名称 ”文本 框 中 输入 “rsdetail” 作 为 该 “记录 集 ” 的 名 称 。 

从 “连接 ”下 拉 列 表 框 中 选择 “webconn” 选 项 连接 对 象 。 

从 “表格 ”下 拉 列 表 框 中 选择 使 用 的 数据 库 对 象 为 “webprice”。 

从 “ 列 ” 选 项 区 中 选中 “全 部 ” 单 选 按钮 。 

在 “筛选 ” 栏 中 设置 记录 集 过 滤 条 件 为 “ID ”一 “=” 一 “URL 参数 ”一 “ID”。 
完成 后 如 图 3-60 所 示 。 

ED 如 果 想 知道 SQL 语句 , 可 以 单 击 LE& 按钮 。 在 高 级 界面 中 查看 SQL 语句 ， 
如 图 3-61 所 示 。SQL 语句 中 的 colname 是 一 个 变量 ， 若 筛选 的 时 候 有 用 到 变量 ， 
Dreamweaver 就 会 把 这 个 变量 名 称 放 在 SQL 语句 里 ， 而 这 个 变量 的 值 会 是 什么 
呢 ? 就 是 下 面 “ 变 量 ” 区 域 中 colname 的 运行 值 的 定义 。 当 网 页 运行 时 ，colname 


将 等 于 URL 变量 ID 的 值 ($_GET[‘ID*])， 所 以 ， 当 URL 的 变量 ID 值 不 同时 ， 和 
选 出 的 结果 也 不 同 。 











字 友 里弄 特 哈 济世 四 蜂 纪 ”|| 红 二 





3-60 设置 rsdetail 记录 集 

















图 3-61 高 级 “记录 集 ” 对 话 框 
ED 然后 单 击 [__ 胡 ] 按 钮 , 完成 记录 集 的 建立 。 依次 把 记录 集 的 各 字段 拖 到 页 面 
上 对 应 的 单元 格 中 ， 如 图 3-62 所 示 。 
完成 后 ， 直 接 按 F12 键 在 浏览 器 中 打开 detailphp 页 面 ， 发 现 内 容 是 空白 的 ， 
如 图 3-63 所 示 。 这 是 怎么 回 事 呢 ? 因为 在 网 址 后 面 没有 带 着 URL 参数 ,当然 记录 
集 里 就 不 会 有 任何 东西 。 
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EE Ez bd - Microsoft Internet Explorer 
地 址 员 圈 http:/127 0.0. 1/web/detail php 
| 文件 中。 多 辑 时 ) 查看 WD) 收 芯 人 ) 工具 GD 帮助 














图 3-63 显示 为 空白 


直接 在 网 址 后 加 上 URL 变量 ID 其 值 可 以 选 1 ~ 10 的 任何 一 个 值 ， 如 这 里 输 
入 “?ID=6”， 然 后 按 Enter 键 ， 网 页 显示 的 结果 如 图 3-64 所 示 。 


名 无 标题 文档 - Wicrosoft Internet Explorer 
地址 如 | 秋 http://127.0.0.1/wab/datail.phyEiic 二 -区 入 关 香 司 搜索 口 加 | 条 
| 文件 四 ”编辑 查看 WD 收 蕊 从 ) 工具 中 帮助 0 






































3-64 ”URL 参数 ID=6 时 的 详细 面板 
而 在 index.php 中 ,每 一 笔记 录 的 网 址 都 带 有 特定 的 参数 链接 到 detail php， 如 
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图 3-65 所 示 。 


地 址 四) | 搬 http://127.0.0. 1/web/index. php?paeeliun_rsdb=1&totalRows_rsdb=10 
文件 中 ”编辑 E) 查看 WD 收 京 4) 工具 WD 玫 助 人 D 


结果 查询 系统 








共有 10 笔 记录 ， 目 前 查看 第 6 笔 至 第 10 笔 
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3-65 单 击 编号 链接 
四 BY 例如 单 击 第 10 个 链接 后 ， 打 开 指 定 记 录 的 详细 页 面 ， 如 图 3-66 所 示 。 


当 无 标题 文 粕 一 Wicrosoft Internet 
地 址 0) | 炎 http://127.0.0.1/webydetsil.php?TD=10 
文件 中 六 辑 E) 查看 WW) 收 芯 人 ) 工具 CO。 帮助 0 


价格 查询 系统 





产品 数量 产品 价格 





3-66 ”打开 指定 记录 的 详细 页 面 


注意 : ”这 里 如 果 不 以 编号 作为 主 链接 也 是 可 以 的 ， 像 我 们 经 常 使 用 到 的 标题 ， 即 单 
击 菜 个 新 闻 标 题 即 可 用 打开 相应 的 详细 页 面 ， 采 用 的 就 是 这 种 技术 。 








本 4| 编辑 记录 集 


数据 库 记 录 在 页 面 上 的 显示 、 重 复 、 分 页 、 计 数 、 显 示 详 细 信 息 的 操作 已 介绍 完毕 ， 
这 里 将 介绍 在 Dreamweaver 中 进行 增加 、 修 改 以 及 删除 记录 的 操作 。 


4.1 增加 记录 的 功能 


在 数据 表 webprice 中 有 4 个 字段 ， 其 中 ID 字段 为 主键 ， 且 附加 了 “自动 编号 ”属性 ， 
因此 在 新 增 记 录 时 不 必 考 虑 ID 字段 ， 只 需 增加 3 个 值 即 可 。 
实现 的 步骤 如 下 。 
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~ PHP+MySsQL 
动态 网 站 设计 己 用 教程 


创建 一 个 空白 的 PHP 网 页 ， 并 命名 为 “addphp”， 先 添加 一 个 表单 ， 再 插入 
一 个 4x2 表格 ， 宽 度 300(120+180)， 依 序 在 表格 前 3 行 第 一 列 的 单元 格 中 输入 提 
示 文本 , 第 4 行 第 二 列 插入 两 个 按钮 : [提交 ]( 提 交 表 单 动作 )、[ 重 于]( 重 设 表 单 动 作 )， 
完成 后 如 图 3-67 所 示 。 


DW 文 # 四 组 扯 四“ 坦 看 四 搬入 () 全 改 国 ” 格 芭 加 人 羡 令 四 站 点 全 重 D 思 帮助 中 | | 如 二 7 辐 | 本 本 司 
< EE 
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和 和 一 和 
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图 3-67 ”建立 表单 并 设计 网 页 


当 需 要 新 增 、 更 新 记录 时 ， 网 页 中 需要 有 一 个 表单 ， 且 表单 元 素 必须 置 于 表单 内 ， 在 
单 击 “ 提 交 ” 按 钮 后 ， 只 有 在 表单 内 的 元 素 会 以 POST 或 GET 的 方式 被 传送 。 

Dreamweaver 中 实现 新 增 、 更 新 记录 时 ， 都 是 把 表单 元 素 的 值 以 POST 的 方式 传送 给 页 
面 ， 当 程序 判断 到 指定 字段 (新 增 记 录 时 ， 字 段 名 为 MM _insert， 当 使 用 了 “插入 记录 ” 服 
务 器 行为 时 ， 该 字段 将 自动 添加 ) 送 出 了 POST 信息 ( 值 为 窗 体 名 称 ) 时 ， 便 执行 新 增 、 更 新 
记录 等 部 分 的 程序 。 

在 第 二 列 的 3 个 单元 格 中 插入 3 个 文本 字段 , 在 “属性 ”面板 中 命名 , 如 图 3-68 

所 示 ， 分 别 是 name、num、price， 设 计时 ， 要 与 记录 和 集 字段 名 称 一 一 对 应 。 






































加 文本 域 字符 宽度 人 类 型 人 单行 G) 。” 口 多 行 轨 。 〇 省 友人 包 ) 类 四 | 无 
price 最 多 字符 数 初始 值 G) | ] ? 
口 某 用 @) 
口 R 读 四 
图 3-68 命名 文本 域 


冰 注意 : 当 表单 元 素 的 命名 与 记录 集 字段 符合 时 ， 在 做 “新 增 记录 ”、“ 更 新 记录 ” 
时 ，Dreamweaver 会 自动 地 将 表单 元 素 与 记录 集 字段 相 匹配 。 


EDRS) 打开 “服务 器 行为 ”面板 ， 单 击 “ 添 加 服务 器 行为 ”按钮 贡 ， 从 弹出 的 下 拉 
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菜单 中 选择 “插入 记录 ”命令 ， 如 图 3-69 所 示 。 
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图 3-69 执行 “插入 记录 ”命令 


EEC 弹出 “插入 记录 ”对 话 框 ， 设 置 插入 记录 属性 ， 选 择 连 接 为 “webconn”， 插 
入 表格 至 “webprice”， 这 是 要 设置 将 记录 添加 到 哪 一 个 数据 表 中 。 在 选择 完 数据 
表 后 ，“ 列 ”区 域 中 便 会 出 现 该 数据 表 内 的 所 有 字段 ， 可 以 在 这 里 设置 哪个 数据 
表 字 段 要 从 表单 中 的 哪个 元 素 获取 值 ， 具 体 的 设置 如 图 3-70 所 示 。 


插入 记录 区 





提交 值 ， 自 : | fornl 























图 3-70 设置 “插入 记录 ”对 话 框 


痊 注意 : ”先前 将 表单 元 素 的 名 称 命名 为 与 数据 库 字段 名 称 相同 ， 所 以 在 建立 “插入 记 
录 ” 时 ，Dreamweaver 便 会 自动 将 它们 配对 。 也 可 以 先 选择 欲 设置 的 字段 ， 由 
“ 值 ” 右 方 的 下 拉 菜 单 中 选择 从 哪个 表单 元 素 取得 值 。 然 后 在 “插入 后 ， 转 
到 ”的 文本 框 中 填 上 “index.php” ， 将 表单 元 素 的 名 称 与 数据 库 内 的 字段 名 
称 命名 为 相同 。 除 了 “插入 记录 ”以 外 ，“ 更 新 记录 ”的 服务 器 行为 也 会 将 
相同 名 称 的 数据 列 与 表单 元 素 自动 地 配对 在 一 起 。 


设置 完成 后 , 在 “服务 器 行为 ”面板 的 列表 中 就 会 多 出 一 项 插入 记录 (如 图 3-71 
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所 示 )， 可 以 双击 该 项 重新 进行 “插入 记录 ”的 设置 。 完 成 后 ， 网 页 上 的 表格 会 变 
成 浅 绿色 的 底 ， 当 然 ， 这 并 不 是 表示 有 错误 ， 而 是 让 我 们 知道 该 表单 使 用 了 “ 服 
务 器 行为 ”。 在 表单 内 也 自动 加 上 了 隐藏 字段 名 称 为 “MM _insert”， 用 来 判断 用 
户 是 否 单 击 “ 提 交 ” 按 钮 送出 信息 ， 以 及 是 否 执 行 “插入 记录 ”部 分 的 程序 代码 。 














DW 7X# 四 轴 四 坦 看 WD 搬入 D 化 职 人 9 下 式 (0) 主人 站 点 全 案 口 人 D 帮助 D | | #1， 后]| 呈 区 滞 
Er 
CH coco 
[| RE RNB DO a Fe | 
价格 坦 询 系 统 





















































3-71 插入 记录 后 的 页 面 效果 


ER 直接 按 Fl12 键 ， 在 浏览 器 中 打开 网 页 ， 输 入 值 如 图 3-72 所 示 ， 单 击 “ 提 交 ” 
按钮 ， 尝 试 新 增 一 笔记 录 。 
名 无 标题 文档 - icrosoft Internet Explorer 


地 址 | 乱 http://127.0.0.1/web/aad php ~ 二 入 关 律 辣 搜索 口 回 | 斋 
文件 @) 编辑) 查看 中 收藏 工具 I) 帮助 和 ) 





价格 查询 系统 


| 产品 名 称 ， htest11 ] 
产品 数量 ， 

产品 价格 ，“[ 辕 
[ 











图 3-72 插入 记录 数据 


单 击 “ 提 交 ” 按 钮 后 ， 网 址 将 从 add.php 转 至 index.php。 单 击 网 页 下 方 的 分 页 
导航 条 的 “最 后 一 页 ”链接 ， 便 可 以 看 到 刚才 新 增 的 记录 ， 如 图 3-73 所 示 。 
我 们 来 简单 地 来 看 看 这 部 分 的 程序 代码 是 怎样 实现 的 。 
表单 的 “动作 ”为 <?php echo $editFormAction: ?>， 单 击 “ 提 交 ” 按 钮 后 ， 网 页 将 信息 
以 POST 方式 传 给 自己 ， 如 图 3-74 所 示 。 
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要 无 标题 文档 -了 icrosoft Internet Ezplorer 
编辑 时 查看 中 收 诚 和 ) 工具 思 帮助 0 本 
-输入 关 主 局 搜索 口 加 | 


文件 @ 
; 地 址 加) | 轿 http://127. 0.0.1/webyindex. php?pageon_rsal=28totalRows_rsal=11 


价格 查询 系统 














共有 11 笔记 录 ， 目 前 查看 第 11 笔 记录 至 第 11 笔 记录 





产品 名 称 


testl1 


[此 = 由 1 
































3-73 ”增加 记录 后 的 效果 





























表单 ID 动作 [rphp echo SeditFornAction; ?> | 已 目标) | | 类 @ | 无 
Eornl | 亨 法 [PosT ~| 编码 头 型 ~| | 








3-74 ”表单 的 动作 参数 


接着 看 到 被 自动 添加 的 隐藏 字段 MM_insert， 其 值 是 form1l1， 与 所 在 网 址 的 表单 名 称 一 
致 ， 代 码 的 窗口 如 图 3-75 所 示 。 

















DW 文件 加 ” 编 强 (5) 查看 WD 插入 QD 修改 人 格式 (四 命 人 ”站 点 (四) 从 DID 帮助 如 | | 二 | 吕 " 辐 | 加 攻 司 
局 Af (imsecl$_5ERYERIQOERY_STRINS'])) ( 9 
36 SeditFormAction .= "?" . htmlentities( RVERTL "QUERY_SIRING']); 
得 | 37 
3 
多 | se (tiasec(s_zosrrmet_ inserc"])) ss (s_FosrInat inserrr] 一 "fors1")) { 
eo insercsor - spztnrs("TysERT INTO webprice (ID，name，num，price) VALUES (ts, 43, 4, 
Se)", 
党 41 GetSQLValueString($_FOST['price'], "text"”), 
四 42 GetSQLValueString($_FOST['name'], "text"), E | 
4 GersQLValuestring (5_FOST[ "nu"], "nc"), LE 
伯 4 GetsQLValueString(s_FOST['price'], "texc")); | 六 | 本 地 视图 习 
45 
© tracaas 本 
sesuit! - nyeql_ mery(s ) or die(aysql_error()); 
| 铂 
Els Ginserteoro - “/web/index.php"; 
国 |Eo ic (isset(s_seaveR['QUERY STRING'])) ( 梧 vebeomn php 118 PIP 六 
51 $inaertGoIo .= (atrpos($insertGoIo, '2°)) 2 "&" : "2"; at 
加 add 4KB PHP 文人 
[m3 SinsertGoTo .= $_SERVER['QUERY STRING']; 而 i ee 
53 } Ey 
C3 henses (apeince (iocation: a, finserteoro)); dil le a 9 六 
到 | } 二 inaex php SIB PHP 文人 
Ee > | 梧 waate php SKB PIT 文人 | 
器 
4 Kf/1 赵 Unicode (WTF-6) 
属性 eal 
一 服务 器 置 标 [可 
了 if (fonction exists CGetsQLYalueStrine")) { 
Es Ey | 


































































图 3-75 ”代码 窗口 
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核心 的 代码 说 明 如 下 : 


if((isset($ POST["MM insert"])) && ($ POST["MM insert"]=="forml")) 

// 判断 表单 变量 $ POST["MM insert"] 是 否 被 设置 ， 且 值 是 否 等 于 forml。 

// 若是 ， 则 执行 下 面 的 插入 记录 动作 

$insertsQL = sprintf( 
"INSERT INTO webprice (name, num, 'Price') VALUES (%s, %s, $s)", 
// 定 义 了 SQL 语句 
GetSQLValueString($S POsT['name'], "text"), 
GetsQLValuestring($ POsST['num’'], "int"), 
GetSQLValueString($ POST['Price'], "text")); 
// 取 值 为 表单 的 变量 

mysql select db($database webconn, $webconn); 

SResultl = mysql query ($insertsQL, $webconn) or die (mysql error()); 
// 连接 数据 库 执行 SQL 语句 

$insertGoTo = "index.php"; 


// 设置 了 在 “插入 记录 ”后 面 跳 转 的 文件 index .php， 它 被 存储 在 变量 $insertGoTo 中 


4.2 更 新 记录 功能 


更 新 记录 功能 是 指 将 数据 库 中 的 旧 数 据 根据 需要 进行 更 新 的 操作 。 这 里 我 们 会 用 前 面 
已 经 使 用 到 的 detaiLphp 文件 。 

更 新 记录 功能 的 操作 步骤 如 下 。 

打开 detail.php 网 页 后 ， 选 择 链接 文字 “修改 ”， 如 图 3-76 所 示 。 


(DW XHD WD) HW) AD AY) MEO 40 EAE BDI WH | Bd ra Ex] 








Fe 

RY ve mm 

[EL 本 
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Ta] 外 于 ~ 。 共 | 天 | 里 了 
5 nw 无 | WD 


= 时 < 
1 i FOV | FAT ameVT | CREE | Xm ED 
司 括 得 EOg%w 到 喜 四] 考 昌 四 口 3 












































图 3-76 选择 链接 文字 
在 “属性 ”面板 中 单 击 如 图 3-77 所 示 的 “浏览 文件 ”图 标 , 为 其 建立 附带 URL 
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参数 的 超级 链接 。 

[4> mL| | 格式 加 ) | 无 辐 | 类 无 ~ BI 往生 此 扫 标 是 四 

配 cs mm 无 ~| 链接 岂 ~ 全 局。 目标 @ 

9 单元 格 。 水 平 名 默认 ~ 不 执行 0 口 ” 青 晤 颜色 G) 厂 ,| [并 蛇 文 件 页 面 必 性 
一 口 站 得 直 四 | 趴 认 ~ 高 中 标题 全 ) 






































3-77 ” 单 击 “ 浏 览 文件 ”图 标 


ERS) 输入 用 来 更 新 记录 用 的 update.php 页 面 ， 然 后 再 单 击 [要 长 按钮， 为 其 建 
立 名 称 为 id、 值 是 rsdetail 记录 集 ID 字段 值 的 URL 参数 ， 如 图 3-78 所 示 。 


生 友 器 弄 特 痊 济世 四 蜂 纪 ”1|| 红 二 


选择 文件 名 自 ; 
Oa i 






































文件 各 :jupdate php 
文件 类 型 Cf); | 所 有 文件 (*.*) 








WRL: webyapdate php 
相对 于 : 站 点 根 目录 WW /web 
在 站 点 定义 中 更 改名 认 的 泛 接 相对 于 





图 3-78 选择 文件 并 设置 参数 
ES 单 击 [_ 右 按钮 ， 完 成 后 的 链接 地 址 如 下 : 


Update.php?ID=<?php echo $row rsdetail['ID']; ?> 


这 样 就 可 以 传递 ID 到 update.php 页 面 ， 如 图 3-79 所 示 。 


























属性 

《mL| 格式 中 无 可 奖 匹 

刀 css TD 无 | 链接 四 |/veb/update php?it 人 php ech 加 [| 本 
=5| 单元 格 。 水 平 中 上 默 认 ”~| 宽 如 | | 不 换行 @) 口 背 晤 颜色 GG) 厂 -| | CE 
下 各 四 购 ”Vv 商 [ | 标题 四 

















图 3-79 传递 ID 至 update.php 页 面 


创建 update php 空白 文档 ， 该 页 面 的 设计 与 详细 信息 detail.php 相同 ， 都 是 要 
利用 接收 到 的 URL 参数 筛选 指定 记录 。 在 “服务 器 行为 ”面板 中 ， 单 击 四 按钮 ， 
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从 弹出 的 下 拉 菜单 中 选择 “记录 集 ”， 如 图 3-80 所 示 。 


[Dw 又 件 昌 ”六 千 昌 。 壹 天 四 ” 半 入 四 攻 疏 加” 守 四 人 四 了 加 全 四 利和 中 | TSD 
[ste coor < — 
CE 3 ee 

WE ERNE | 





价 交 走光 系统 i 








这 于 Pe Fa | 严 品 价格 
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更 克服 务 强力 1 
ne sn 
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mn | 
Ey | 
swGy NI 00 vv T2542 RAT 和 ticete TFT 
| 局 竹 
[EEC ~ 大 天 
[ET 人 > 
立 件 活动 已 守成 ， [LEE 














3-80 选择 “记录 集 ” 


ESRD 打开 “记录 集 ” 对 话 框 后 ， 在 该 对 话 框 中 进行 如 下 设置 : 

e@ 在 名 称 文本 框 中 输入 “rsupdate” 作 为 该 “记录 集 ” 的 名 称 。 
从 连接 下 拉 列 表 框 中 选择 “webconn” 连 接 对 象 。 
从 表格 下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 “webprice”。 
在 列 单 选 按钮 组 中 选中 “全 部 ” 单 选 按钮 。 
在 筛选 栏 中 设置 记录 集 过 滤 条 件 为 “ID” 一 “=” 一 “URL 参数 ”一 “ID”。 
完成 后 的 设置 如 图 3-81 所 示 。 












































图 3-81 设置 “记录 集 ” 对 话 框 
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GG 


ED 将 页 面 中 应 该 有 的 表单 、 文 本 字段 、 按 钮 设置 完成 ， 在 “ 绑 定 ”面板 中 将 记 



























































rapiste hl | eewpdote nne] | | [espdate men 


录 集 内 的 字段 拖 动 至 页 面 上 各 对 应 的 文本 字段 中 ， 如 图 3-82 所 示 。 多 
| DW 坟 伯 四 交 四 兰 四 半 入 四 名 有 家 下 鲜 日 着 目 Dy BM 证 慢 ” 辐 王 医 国 - 

| | | Wt | SRNR Fd iD, a 于 3 一 素 

芥 桥 查 询 系统 飞 

= 

严 晤 各 称 I 的 
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[oa [oy 


En 
[EC 于 | 无 
本 号 ng 区 ~ 
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EE 



































3-82 ” 绑 定 字段 


由 于 ID 是 主键 ， 不 能 随便 变更 主键 的 值 ， 因 此 选择 ID 部 分 的 文本 字段 ， 单 
击 鼠 标 右键 ， 从 弹出 的 快捷 菜单 中 选择 “编辑 标签 <input>”， 如 图 3-83 所 示 。 


DW 文件 编辑 查看 WD 插入 (D 修 汉 如 格式 (0) 命 人 人 站 点 (加 官 口 D 帮助 人 | | Wi 


























































































































Ea 
一 | 名 一 文档 类 型 ; PIC 
| 的 到 | 折 直 设计] 实时 代码 三流。 条 时 视图， 检查。 [局 标题 :页 本 新 本 3 
| 了 更 新 记录 (fernl, webevnn, webpriee) 
从 询 系统 动态 文本 域 nane) 
00 十 动态 文 地 域 mum) 
二 ~ ‘price) 
品名 称 万 品 数量 
Tr 一 sapdate rua] ] [eeupdsto. price) 
bd 各 高 0 和 NR 
值 | >| 
SRS Bw 滞 jaa 田 关 
环境 标签 人 EYE Rg 
划 辽 标 签 罗 npaty FE TXT 
[CSS 样式 C) 
驶 切 虹 ) 
< 拓 贝 们 ) 到 [VJ A ox 1725x281 Ek/ Unicrde OTP-6) 
| Se 孜 -. 
一 并 展 性 双 ) OB OZS 生 OBE 关口 无 | 
辣 最 多 字 行 数 he echo worsottpirl ?| 
Ow 
回 只 读 @@) 


























图 3-83 设置 “编辑 标签 ”命令 


TY 在 “常规 ”页 中 进行 如 图 3-84 所 示 的 设置 。 通 过 这 样 的 设置 ， 这 个 字段 便 不 
能 被 用 户 修改 了 。 其 他 字段 也 依 此 进行 设置 ， 但 不 选中 “只 读 ” 复 选 框 。 
ED 在 “服务 器 行为 ”面板 中 单 击 [和 E| 按 钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “更 新 记录 ” 
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选项 ， 如 图 3-85 所 示 。 


标签 编辑 器 一 input 























onkeyPress 
onkeyDown 
onkeylp 
onSelect 























图 3-84 设置 为 “只 读 ” 属 性 
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. ad > . 有 区 可 
| 天 品名 称 大 品 雪 量 大 吕 价 各 | 本 
rsupdate, rane) | [irsupdate. un) | | [rsupdste, price} 搬入 记录 
CEaE 
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[ee 于 玉民 所 15 | 区 型 器 曲 行 加 〇 SW 。 Oe) 区 0) 无 入 ue 
三 ] 最 多 字符 灼 ] 初始 入 抵 ) [Grhs scho rer rrdatef ij ?| 逐 本 He 
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图 3-85 执行 “更 新 记录 ”命令 


ED 弹出 “更 新 记录 ”对 话 框 ， 设 置 更 新 记录 的 参数 。 筛 选 连接 “webconn” 后 ， 
每 个 表单 元 素 与 字段 都 会 自动 匹配 好 ， 只 需 在 “在 更 新 后 ， 转 到 ”文本 框 中 输入 
“/web/index.php”， 如 图 3-86 所 示 。 

EDPD 单 击 [ 胡 按钮， 完成 后 ,页 面 的 表格 同样 会 被 套 上 浅 绿色 的 底 纹 , 而 表单 
中 也 会 多 出 一 个 隐藏 字段 ， 名 称 为 MM_update， 值 与 表单 相同 ， 如 图 3-87 所 示 。 

最 后 ， 在 浏览 器 中 打开 index.php， 选 择 最 后 一 笔记 录 到 详情 页 面 detailphp， 
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在 详情 页 面 中 单 击 “ 修 改 ” 链 接 ， 如 





3-88 所 示 。 
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图 3-87 ”完成 的 页 面 效果 


E 无 标题 文档 - 和 icrosoft Internet Ezplorer 
地 址 四) | 类 http://127.0.0.1/web/detail. php?ID=11 
1 文件 中 编辑) 查看 WD 收 豪 W) 工具 I) 帮助 


价格 查询 系统 






































图 3-88 单 击 “ 修 改 ” 链 接 
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在 update.php 页 面 中 可 以 修改 姓名 、 年 龄 和 成 绩 的 字段 值 ， 而 ID 文本 字段 是 
不 能 被 修改 的 ， 更 改 完成 后 ， 单 击 “ 修 改 ” 按 钮 ， 如 图 3-89 所 示 。 


地 址 四) | 四 http://127.0.0. 1/web/update. php?ID=11 
文件 四 编辑 下 ) 查看 W) 收藏 和 工具 CD 家 助 0 








价格 查询 系统 





产品 名 称 产品 数量 


[est [mo 


加 加 





























图 3-89 修改 数据 
ED 返回 到 index.php， 检 查 该 笔记 录 是 否 被 正确 更 新 ， 如 图 3-90 所 示 。 


EE 
地 址 四 ) | 国 http://127.0.0.1/web/index. php?pageliom_rsdb=2AtotulRows_rsdb=11AID=11 
文件 中) 编辑 时) 查看 WD 收藏 WW) 工具 CD 帮助 0 


价格 查询 系统 


共有 11 笔记 录 ， 目 前 查看 第 11 笔 至 第 11 笔 








图 3-90 ”完成 更 新 的 功能 界面 


这 部 分 的 程序 代码 与 插入 记录 的 程序 代码 基本 相同 ， 差 别 只 在 于 隐藏 字段 的 名 称 不 同 ， 
使 用 的 是 UPDATE 语句 。 


4.3 ”删除 记录 功能 


删除 记录 功能 是 将 数据 从 数据 库 中 删除 ， 使 用 “服务 器 行为 ”中 的 “删除 记录 ”命令 
即 可 实现 。 
具体 的 实现 步骤 如 下 。 
通过 超级 链接 带 着 URL 参数 转 到 删除 页 面 delphp。 首 先 ， 在 detailphp 中 选 
中 “删除 ”， 在 “属性 ”面板 中 建立 链接 ， 如 图 3-91 所 示 。 
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图 3-91 设置 “删除 ”链接 


ER 因为 删除 记录 还 是 依据 主键 的 ID 字段 ， 故 选择 删除 记录 所 用 文件 delphp， 并 
附带 URL 参数 ， 其 名 称 为 DD， 值 为 rsdetail 记录 和 集 的 ID 字段 值 ， 如 图 3-92 所 示 。 


选择 文件 
































|/web/ adel php 
| 站 点 根 目录 本 /web 
在 站 点 定义 中 匡 疏 于 兴国 注 接 可 对 于 








图 3-92 设置 传递 的 参数 属性 


EEC) 单 击 [ 按钮 , 完成 detailphp 的 修改 工作 。 创建 del.php 文件 , 在 “ 绑 定 ” 
面板 中 单 击 [| 按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “记录 集 ”， 如 图 3-93 所 示 。 
EEC 会 出 现 “ 记 录 集 ”对 话 框 ， 在 该 对 话 框 中 进行 如 下 设置 : 
@ 在“ 名称” 文本 框 中 输入 “rsdel” 作 为 该 记录 和 集 的 名 称 。 
@ ”从 “连接 ”下 拉 列 表 框 中 选择 “webconn” 连 接 对 象 。 
@ 从“ 表格” 下拉 列表 框 中 ， 选 择 使 用 的 数据 表 对 象 为 “webprice”。 
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@ 在 “ 列 ” 单 选 按钮 组 中 选中 “全 部 ” 单 选 按钮 。 
@ 在 “筛选 栏 中 设置 过 滤 条 件 为 WII | “URL 参数 ” “Hy 
完成 后 的 设置 如 图 3-94 所 示 。 
DW z 四 请 四 查看 四 搬入 四 各 改 加 术 并 加 全 和 器 回 自 Dp 部 二 四 | | 商 慢 ” 辐 加 屋 滞 
加 的 让 区 加 蚂 x3% nn 
| ml Bi mt EA a A Ot 
价格 查询 系统 
:也 台 名 入 EE 局 全 福 
E23 
1 
E22 
rr 
G15 全 | 名 
[sy yn TE S23 2 /1 Wiccae QT?-8) 
LS 
[om 四 [RE ~ 莱 | 元 ~ BaZ 丘 二 妇 直 村 要 0) 
TE ~ = 上 四 
[RERH jg7= 全 六 伴 允 克成 [EE 
I | 




















3-93 ”选择 “记录 集 ” 


: [rsdell 





:|webconn 





: [webprice 
































图 3-94 设置 “记录 集 ” 属 性 


将 各 个 记录 集 字段 拖 动 到 页 面 中 所 对 应 的 文本 框 后 ， 将 “删除 ”按钮 命名 为 
Del， 然 后 在 “服务 器 行为 ”面板 中 单 击 轩 按钮， 从 弹出 的 下 拉 菜 单 中 选择 “删除 
记录 ”， 如 图 3-95 所 示 。 
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狂 注意 : “主键 列 ” 与 “主键 值 ” 所 设置 的 是 删除 记录 的 依据 。 这 里 的 依据 是 指 在 
DELETE FROM 数据 表 WHERE 条 件 里 的 条 件 , 假设 条 件 是 WHERE ID=11， 
相应 地 ， 可 以 看 成 WHERE 主键 列 = 主 键 值 。 在 这 里 ， 并 不 一 定 要 选择 数据 库 
中 的 主键 来 当 作 主 索引 字段 。 


DW 文件 轨 尊 久 四 要 看 四 半 入 四 售 织 则 -闪光 四 证 人 加 总 回 家 PD 昌 各 四 证 二 ” 辐 | 瑟 区 司 
















字 友 器 型 特 叭 济世 四 蜂 纪 ”|| 绪 匡 











EE 大 品名 称 
| [em mr | fredel. ranel 
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EE 
































3-95 ”选择 “删除 记录 ” 
ES 在 弹出 的 “删除 记录 ”对 话 框 中 进行 如 图 3-96 所 示 的 设置 。 


首先 检查 是 否 已 定义 变量 : | 主键 值 
连接 : |vebconn 
表格 : | vebprice 





主键 列 : [ 
主键 值 : [URL 参数 
册 除 后 ， 转 到 : index. Php 





图 3-96 设置 删除 记录 的 参数 


单 击 [__ 克 E ] 按 钮 ， 完 成 设置 。 

本 模块 中 , 我 们 学 习 了 最 基本 的 Dreamweaver CS5.5 内 置 服务 器 行为 的 操作 和 使 用 ,并 
且 了 解 了 其 原始 程序 代码 的 意义 。 在 后 面 的 章节 中 ， 如 用 户 管理 系统 、 留 言 管理 系统 、 新 
闻 管 理 系统 等 ， 都 将 用 到 这 些 基 础 的 操作 。 
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用 户 管理 系统 实例 的 设计 


在 网 站 建设 开发 中 ， 第 一 个 要 接触 的 就 是 用 户 管理 系统 的 开发 ， 
即 网 站 提供 给 会 员 注册 并 能 登录 进行 一 些 操作 的 基础 功能 。 

一 个 典型 的 用 户 系统 , 一 般 应 该 有 用 户 注 册 功 能 、 资 料 修改 功能 、 
取 回 密码 功能 及 用 户 注 销 身份 功能 等 。 

本 章 将 把 前 几 章 介绍 的 知识 加 以 灵活 应 用 。 本 章 的 实例 中 主要 用 
到 创建 数据 库 和 数据 库 表 、 建 立 数据 源 连 接 、 建 立 记 录 集 、 创 建 各 种 
动态 页 面 、 添 加 重复 区 域 来 显示 多 条 记录 、 页 面 之 间 传 递 信息 、 创 建 
导航 条 、 隐 藏 导航 条 链接 等 技巧 和 方法 。 


。 本 模块 的 任务 重点 。 








用 户 管理 系统 网 站 结构 的 搭建 
创建 数据 库 和 数据 库 表 

建立 数据 源 连接 

掌握 用 户 管理 系统 中 页 面 之 间 信 息 传递 的 技巧 和 方法 
用 户 管理 系统 常用 功能 的 设计 与 实现 
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国 ] 1 | 用户 管 理 系统 的 规划 


在 开发 用 户 管理 系统 之 前 ， 要 做 好 整个 系统 的 规划 ， 例 如 ， 在 注册 时 需要 采集 哪些 资 
料 ， 是 否 提供 在 线 修改 密码 等 操作 ， 这 样 能 够 方便 后 面 整 个 系统 的 开发 与 制作 。 下 面 就 来 
介绍 用 户 管理 系统 的 整体 规划 工作 。 


1.1 页 面 规划 设计 


用 户 管理 系统 分 成 用 户 登 录入 口 与 找 回 密码 入 口 两 个 部 分 ， 其 中 ，mindex.php 是 这 个 
网 站 的 首页 。 在 本 地 的 计算 机 设置 站 点 服务 器 ， 在 Dreamweaver CS5.5 的 网 站 环境 按 F12 
键 来 浏览 网 页 ， 或 者 在 正 浏览 器 的 地 址 栏 中 输入 “http://localhostmember/mindex.php” 来 
打开 用 户 系统 的 首页 ， 其 中 member 是 站 点 名 。 

本 实例 共有 12 个 页 面 ， 各 个 页 面 的 名 称 和 对 应 的 功能 如 表 4-1 所 示 。 


表 4-1 用 户 管理 系统 中 各 网 页 的 功能 








页 面 功 能 
mindex.php 用 户 开始 登录 的 页 面 
welcome.php 用 户 登 录 成 功 后 显示 的 页 面 
loginfail.php 用 户 登 录 失败 后 显示 的 页 面 
register.php 新 用 户 用 来 注册 个 人 信息 的 页 面 
regok.php 新 用 户 注册 成 功 后 显示 的 页 面 
regfail.php 新 用 户 注 册 失 败 后 显示 的 页 面 
lostpassword.php 丢失 密码 后 进行 密码 查询 使 用 的 页 面 
showquestion.php 查询 密码 时 输入 提示 问题 的 页 面 
showpassword.php 答对 查询 密码 问题 后 显示 的 页 面 
userupdate.php 修改 用 户 资料 的 页 面 
userupdateok.php 成 功 更 新 用 户 资料 后 显示 的 页 面 
logout.php 退出 用 户 系 统 的 页 面 


1.2 搭建 系统 数据 库 


通过 对 用 户 管理 系统 功能 的 分 析 ， 可 以 发 现 ， 数 据 库 应 该 包括 注册 的 用 户 名 、 注 册 密 码 
以 及 一 些 个 人 信息 ， 如 性 别 、 年 龄 、E-mail、 电 话 等 ， 所 以 数据 库 中 必须 包含 一 个 容纳 上 述 
信息 的 表 ， 称 为 “用 户 信息 表 ”， 数 据 库 命名 为 member。 搭 建 数据 库 的 过 程 如 下 。 
ES 在 IE 浏览 器 地 址 栏 中 输入 “http://127.0.0.1/phpMyAdmin/”, 在 登录 界面 输入 
MySQL 的 用 户 名 “root” 和 密码 “admin”， 在 phpMyAdmin 管理 界面 单 击 选择 
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[部 数 据 库 ,命令 ， 打 开本 地 的 “数据 库 ” 管 理 页面 ， 在 “新 建 数据 库 ” 文 本 框 中 输 
入 数据 库 的 名 称 “member”， 单 击 打开 后 面 的 数据 库 类 型 下 拉 菜单 ， 在 弹出 的 选 
择 项 中 选择 utf8_bin 选项 ， 如 图 4-1 所 示 。 单 击 “ 创 建 ” 按 钮 BB 树 ]， 返 回 “ 常 规 设 
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MySQL localhost ， 协 认 顺丰 10 
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WSL Fe; UT -0 Uncode 
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网 站 服务 器 


» Apache/2.0.63 (Win32) 
PhP/5.2.14 
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4-1 创建 member 数据 库 


单 击 左边 的 member 数据 库 将 其 连接 上 ， 打 开 “ 新 建 数据 表 ” 页 面 ， 输 入 数据 


表 名 “member”， 在 


“字段 数 ” 文 本 框 中 输入 本 数据 表 的 字段 数 为 “12”， 表 示 


将 创建 12 个 字段 来 储存 数据 ， 再 单 击 区 司 按钮 ， 切 换 到 数据 表 的 字段 属性 设置 页 
面 ， 输 入 数据 字段 名 并 设置 数据 字段 的 相关 数据 ， 如 图 4-2 所 示 。 


Er 
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4-2 建立 member 数据 表 
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各 字段 如 表 4-2 所 示 ， 这 个 数据 表 主 要 是 记录 每 个 用 户 的 基本 数据 、 加 入 的 时 间 ， 以 及 
登录 的 账号 和 密码 。 
表 4-2 ”member 数据 表 
字段 名 称 字段 类 型 字段 大 小 说 明 
ID int 11 用 户 编 码 
Username varchar 20 用 户 账号 
password varchar 20 用 户 密码 
question Varchar 50 找 回 密码 提示 
answer varchar 50 找 回 密码 答案 
truename varchar 50 真实 姓名 
sex varchar 10 性 别 
address varchar 50 地 址 
tel varchar 50 电话 
QQ varchar 20 QQ 号 码 
email varchar 50 邮箱 
authori char 1 登录 区 分 











这 里 创建 的 数据 表 有 12 个 字段 ， 读 者 在 开发 其 他 用 户 管理 系统 的 时 候 ， 可 以 根据 采集 
用 户 信息 的 需要 ， 加 入 更 多 的 字段 。 


1.3 用户 管理 系统 站 点 


在 Dreamweaver CS5.5 中 创建 一 个 用 户 管理 系统 网 站 站 点 member, 由 于 这 是 PHP 数据 
库 网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 4-3 所 示 。 
表 4-3 站 点 设置 的 基本 参数 














站 点 名 称 member 

本 机 根 目 录 C:\Apache\htdocs\member 

测试 服务 器 C:\Apache\htdocs\ 

网 站 测试 地 址 http://127.0.0.1/member/ 

MySQL 服务 器 地 址 C:\Apache\MySQL-5.0.90\data\imember 
管理 账号 /密码 root/admin 

数据 库 名 称 member 


创建 member 站 点 的 具体 操作 步骤 如 下 。 
EJP 首先 在 C:\Apache\htdocs 路 径 下 建立 member 文件 夹 ， 如 图 4-3 所 示 ， 本 单元 
建立 的 所 有 网 页 文件 都 将 放 在 该 文件 夹 下 。 
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国 对 项 


篇 C:\apache\htdocs 
文件 四 ”编辑 下 查看 中 
BE- OO 全 PR 
地 址 呈 ) 回 C:\Apache\htdocs 





半 克 里 型 特 瞪 淋 须 咀 卫 泗 


4-3 ”建立 站 点 文件 夹 member 


EU 运行 Dreamweaver CS5.5， 执 行 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 弹 
出 “管理 站 点 ”对 话 框 ， 如 图 4-4 所 示 。 





























图 4-4 “管理 站 点 ”对 话 框 


ETE> 对 话 框 的 左边 是 站 点 列表 框 , 其 中 显示 所 有 已 经 定义 的 站 点 。 单 击 [EBD 按 
钮 ， 弹 出 “站 点 设置 对 象 ”对 话 框 ， 进 行 如 图 4-5 所 示 的 参数 设置 。 


ee ee 的 所 各 次 件 和 深 守 的 各 全 pr 
Ee 2 a 
您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 赤 和 名 称 . 
站 点 名 称 : [member 
本 地 站 点 文件 夷 ; [Cpahe hocs menber\ 















































4-5 建立 member 站 点 


ES 单 击 左 侧 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 所， 打开 
“基本 ”选项 卡 ， 进 行 如 图 4-6 所 示 的 参数 设置 。 
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站 点 设置 对 象 aeaber 





| 设置 未 自 











| 








C: Wpache\htdocs 

















[http://127.0.0, Umember/ | 测试 | 
























































图 4-6 “基本 "选项 卡 的 设置 
区 于 BY 设置 后 ， 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 界面 ， 选 中 “维护 


同步 信息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 选择 PHP MySQL， 表 示 是 使 
用 PHP 开发 的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 4-7 所 示 。 





[一 |sake 





回 维护 同步 信息 
口 保存 时 自动 格 文件 上 传 到 服务 器 
口 局 用 文件 取出 功能 
古 打开 廊 件 之 前 职 出 MR 
职称 :全 | D 
电邮 地 i 直 : 


有 Wb 办 发 

































































图 4-7 设置 “高 级 ”选项 卡 
EC 单 击 [ 全 | 按钮 ,返回 “ 服 务 器 ”设置 界面 ， 选 中 “测试 ” 复 选 框 ， 如 
图 4-8 所 示 。 
单 击 [ ”保存 ”| 按钮 ， 即 可 完成 站 点 的 定义 设置 ， 在 Dreamweaver CS5.5 中 
就 有 了 刚才 所 设置 的 站 点 member, 单 击 蕊 过 划 面 按钮, 关闭 “管理 站 点 ”对 话 框 ， 
这 样 就 完成 了 Dreamweaver CS5.5 测试 用 户 管理 系统 网 页 的 网 站 环境 设置 。 
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GE 


| 





图 4-8 设置 “服务 器 ”参数 


1.4 ”设置 数据 库 连接 


完成 了 站 点 的 定义 后 ， 接 下 来 就 是 用 户 系统 网 站 与 数据 库 之 间 的 连接 ， 网 站 与 数据 库 
的 连接 设置 如 下 。 
新 建 空白 PHP 文档 , 输入 网 页 标题 “用 户 管理 系统 ”, 保存 为 “mindex.php”， 
如 图 4-9 所 示 。 





图 4-9 新 建 mindex.php 网 页 
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ED 选择 菜单 栏 上 的 “窗口 ”一 “数据 库 ” 命 令 ， 打 开 “ 数 据 库 ” 面板 。 在 “ 数 
据 库 ” 面板 中 单 击 “MySQL 连接 ”按钮 [ 世 ， 并 在 打开 的 下 拉 菜 单 中 选择 “MySQL 
连接 ”选项 ， 如 图 4-10 所 示 。 





4-10 选择 “MySQL 连接 ” 


ES 在 “MySQL 连接 ”对 话 框 中 ， 输 入 连接 名 称 为 “mymember”，MYySQL 服务 
器 名 为 “localhost”， 用 户 名 为 “root”、 密 码 为 “admin”。 选 择 所 要 建立 连接 的 
数据 库 名 称 ， 可 以 单 击 [选取 .| 按钮 浏览 MySQL 服务 器 上 的 所 有 数据 库 ， 选 择 刚 
导入 的 范例 数据 库 “member”， 如 图 4-11 所 示 。 


连接 名 称 : mymenber 
WySQL 服务 器 : |1ocalhost 
用 户 名 : root 
密码 : [eety 
数据 库 : menber 




















4-11 设置 MySQL 连接 参数 


单 击 [一] 按钮 测试 与 MySQL 数据 库 的 连接 是 否 正确 ， 如 果 正确 ， 则 弹 
出 一 个 提示 消息 框 (如 图 4-12 所 示 )， 这 表示 数据 库 连 接 设置 成 功 了 。 














图 4-12 设置 成 功 


EEC) 单 击 [ 克 E ”| 按钮 ， 则 返回 编辑 界面 ， 在 “数据 库 ” 面 板 中 显示 绑 定 过 来 的 
数据 库 ， 如 图 4-13 所 示 。 
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目 剧 需 





忆 。 answer (varchar 50 必需 的 ) 
:图 Se Nh 


图 4-13 ” 绑 定 的 数据 库 





了 而 加班 类 些 洲 内 中 并 瑾 





国 B]2| 用 户 登录 功能 


这 里 主要 介绍 用 户 登录 功能 的 制作 ， 用 户 管理 系统 的 第 一 个 功能 就 是 要 提供 一 个 所 有 
会 员 进行 登录 的 窗口 。 


2.1 设计 登录 页 面 


在 用 户 访问 该 用 户 管理 系统 时 ， 首 先 要 进行 身份 验证 ， 这 个 功能 是 靠 登录 页 面 来 实现 
的 ， 所 以 ， 登 录 页 面 中 必须 有 要 求 用 户 输入 用 户 名 和 密码 的 文本 框 ， 以 及 输入 完成 后 进行 
登录 的 “登录 ”按钮 ， 以 及 输入 错误 后 重新 设置 用 户 名 和 密码 的 “ 重 置 ”按钮 。 

详细 的 制作 步骤 如 下 。 

打开 前 面 创建 的 mindex.php 页 面 ， 按 图 4-14 所 示 的 效果 进行 设计 。 


加 
是 








@56 加 -回国 力 育 R 天 四 六- 
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会 员 登 录 
Tr 严 品 8 明 
月 户 各 ET 靶 林 手写 WB 外 现 委 等 桂 点 。 
久 | te: aa0 
[Ezaleia 人 RN: 60 


注册 新 生 户 失语 守 码 


产品 分 类 
学 上 记 庙 
hit 
四 Hi 村 
古村 机 


中 兴 是 攻 产 中 沁 手 可 中 最 条 上 


图 4-14 用 户 登 录 系 统 的 首页 


EDP 从 菜单 栏 选 择 “修改 ”一 “页 面 属 性 ”命令 ， 然 后 在 “背景 颜色 ”文本 框 中 
输入 颜色 值 为 “#cccccc”， 在 “上 边 距 ”文本 框 中 输入 0px， 这 样 设置 的 目的 ， 
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是 为 了 让 页 面 的 第 一 个 表格 能 置顶 到 上 边 ， 并 形成 一 个 灰色 底 纹 的 页 面 ， 设 置 情 
况 如 图 4-15 所 示 。 


外 观 CsS) 
页 面 字 体 @) : | 默认 字体 
大 小 @): |12 
文本 颜色 四 ): 辐 | 
背 且 颜色 @B): 国 |Eceeee | 
青 晤 图 入 江 ) 





重复 E) 


左边 距 旭 
上 边 距 下 ): 中 














帮助 QD 











图 4-15 “页 面 属 性 ”对 话 框 


ET 设置 完成 后 ， 单 击 [BE 按钮 ， 进 入“ 文档” 窗口， 从 菜单 栏 选择 “插入 ” 
一 “表格 ”命令 ， 弹 出 “表格 ”对 话 框 ， 按 如 图 4-16 所 示 进 行 参数 设置 。 
































图 4-16 设置 “表格 ”属性 


EEC 单 击 [__ 砍 E | 按 钮 , 在 “文档 ”窗口 中 插入 了 一 个 3 行 3 列 的 表格 。 将 鼠标 
放置 在 第 1 行 表格 中 ， 将 第 1 行 表格 合并 ， 在 “属性 ”面板 中 单 击 “ 合 并 所 选 
单元 格 ， 使 用 跨度 ”图 标 按钮 回 ， 然 后 从 菜单 栏 选 择 “插入 ”一 “图 像 ” 命 令 ， 
打开 “选择 图 像 源 文件 ”对 话 框 ， 在 站 点 下 的 images 文件 夹 中 选择 图 片 01.gif， 
如 图 4-17 所 示 。 单 击 [并 证 “按钮 ， 把 图 片 插入 表格 中 。 

GTB 同样 ， 合 并 表格 第 3 行 的 所 有 单元 格 ， 选 择 站 点 member 下 images 文件 夹 中 
的 文件 02.gif 插 入 其 中 ， 播 入 后 的 效果 如 图 4-18 所 示 。 
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文件 名 如: [0l. aif ] T75 x 231 GIF, 4 E/T 
文件 类 型 中。 | 图 各 文件 (sif;+ jpe;*_jpee;*.pne;* | 





守 克 丑 型 特 瞪 淋 须 咀 卫 泗 





images/0L gif 








图 4-17 “选择 图 像 源 文 件 ” 对 话 框 


中 chpache htdors mtaber\indes .php -Ox 
menber phy 

















| 加 
oly> NW A Oo0x ~ 787 x 345v 9K /7 牧 Unicode (VTF-S) 


4-18 ”插入 图 片 后 的 效果 


EEC 选择 整个 表格 ， 在 “属性 ”面板 的 “对 齐 ” 下 拉 列 表 框 中 ， 选 择 “ 居 中 对 齐 ” 
选项 ， 设 置 表格 相对 页 面 水 平 居中 对 齐 ， 如 图 4-19 所 示 。 








大 虽 | 训 mFrs ] 地表 辟 | 基 天 in | 对 齐 如 居中 对 齐 | 类 加 | 无 | 
| op | IEGp_ ] iaEop | 








HR Mo 
5 








图 4-19 设置 “居中 对 齐 ” 


EC 选择 表格 第 2 行 第 1 个 单元 格 ， 在 “属性 ”面板 中 设置 高 度 为 456 像素 、 宽 
度 为 179 像素 (设置 的 高 度 和 宽度 根据 背景 图 像 而 定 )。 切 换 到 代码 视图 ， 在 <td> 标 
记 中 增加 以 下 中 粗 体内 容 : 


<tqd width="179" height="456" background="/member/images/02.gif"> 


说 明 : 单元 格 设置 背景 图 片 只 能 通过 修改 标记 来 完成 ， 效 果 如 图 4-20 所 示 。 
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4-20 ”插入 图 片 的 效果 


在 表格 的 第 2 行 第 2 列 和 第 3 列 中 ， 分 别 插入 同一 站 点 里 images 文件 夹 中 的 
图 片 03.gif 和 04.gif， 完 成 网 页 的 结构 搭建 ， 如 图 4-21 所 示 。 
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图 4-21 完成 的 网 页 背景 效果 
单 击 第 2 行 第 1 列 单元 格 ， 然 后 单 击 “ 文 档 ” 窗 口上 的 [ 允 习 按钮 ， 在 <tt> 和 


</td> 之 间 加 入 valign=“top” 命 令 (也 可 以 在 属性 面板 进行 垂直 对 齐 方式 设置 )， 使 单 
击 后 鼠标 能 够 自动 地 贴 至 该 单元 格 的 最 顶部， 设置 如 图 4-22 所 示 。 
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4-22 ”设置 单元 格 的 对 齐 方式 为 最 上 


和 注意 : ”文档 工具 栏 中 包含 按钮 和 弹出 的 菜单 ,它们 提供 各 种 文档 “窗口 视图 ”( 如 “ 设 
计 ”、“ 拆 分 ”和 “代码 ”视图 )、 各 种 查看 选项 和 一 些 常用 操作 (如 在 浏览 器 
中 预览 )。 


ED 单 击 “ 文 档 ” 窗 口上 的 [车 按 钮 ， 返 回 文档 窗口 的 “设计 ”窗口 模式 ， 在 刚 
创建 的 表格 的 单元 格 中 ， 从 菜单 栏 中 选择 “插入 ”一 “表单 ”一 “表单 ”命令 ， 
如 图 4-23 所 示 ， 插 入 一 个 表单 。 
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图 4-23 执行 “表单 ”命令 
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ED 将 鼠标 指针 放置 在 该 表单 中 ， 从 菜单 栏 中 选择 “插入 ”一 “表格 ”命令 ， 插 
入 一 个 5 行 1 列 的 表格 ， 宽 度 179。 表 格 各 行 的 高 度 分 别 是 35、23、23、24、24。 
选择 第 2 行 单元 格 并 设置 为 水 平 居中 对 齐 。 输 入 文字 说 明 “ 用 户 名 ”， 其 后 插入 
一 个 单行 文本 域 表单 对 象 ， 并 定义 文本 域名 为 “usermame”， “文本 域 ”属性 的 设 
置 如 图 4-24 所 示 。 


属性 
回迁 字符 宽度 四 [12 类 HO OS 和 OND 类 | 无 | 
[asernane 最 多 字符 数 | 初 她 值 G) 多 

口 划 用 四 

口 R 送 加 
































图 4-24 “文本 域 ” 属 性 的 设置 


设置 文本 域 的 属性 说 明 如 下 。 

(1) 在 “文本 域 ”文本 框 中 ， 为 文本 域 指定 一 个 名 称 ， 每 个 文本 域 都 必须 有 一 个 唯一 
名 称 。 表 单 对 象 名 称 不 能 包含 空格 或 特殊 字符 。 可 以 使 用 字母 、 数 字 字符 和 下 划 线 (_) 的 任 
意 组 合 。 请 注意 ， 为 文本 域 指定 的 标签 是 存储 该 域 的 值 (输入 的 数据 ) 的 变量 名 ， 这 是 发 送 给 
服务 器 进行 处 理 的 值 。 

(2) “字符 宽度 ”设置 域 中 最 多 可 显示 的 字符 数 。“ 最 多 字符 数 ” 指 定 在 域 中 最 多 可 
以 输入 的 字符 数 ， 如 果 保 留 为 空白 ， 则 输入 不 受 限 制 。“ 字 符 宽 度 ” 可 以 小 于 “最 多 字符 
数 ”， 但 大 于 字符 宽度 的 输入 则 不 被 显示 。 

(3) “类 型 ”用 于 指定 文本 域 是 “单行 ”、“ 多 行 ”， 还 是 “密码 ” 域 。 单 行文 本 域 
只 能 显示 一 行文 字 ， 多 行 则 可 以 输入 多 行文 字 ， 达 到 字符 宽度 后 换行 ，“ 密 码 ” 文 本 域 则 
用 于 输入 密码 。 

(4) “初始 值 ”指定 在 首次 载 入 表单 时 ， 域 中 显示 的 值 。 例 如 ， 通 过 包含 说 明 或 示例 
值 ， 可 以 指示 用 户 在 域 中 输入 信息 。 

(5) “类 ”可 以 将 CSS 规则 应 用 于 对 象 。 

EEP9 选择 第 3 行 单元 格 ， 设 置 为 水 平 居中 对 齐 。 输 入 文字 说 明 “密码 ”， 插 入 密 

码 文本 域 表 单 对 象 ， 定 义 “ 文 本 域 ”名 为 “password”，“ 文 本 域 ” 的 属性 设置 如 
图 4-25 所 示 。 
证 | a 二 Og 类 @| 无 | 


口 菜 用 吓 
口 R 于 四 

















图 4-25 密码 “文本 域 ”的 设置 
ESEE) 选择 第 4 行 单元 格 ， 设 置 为 水 平 居中 对 齐 。 从 菜单 栏 中 选择 “插入 ”一 “ 表 
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单 ” 一 “按钮 ”命令 两 次 ， 插 入 两 个 按钮 ， 并 分 别 在 “属性 ”面板 中 进行 属性 设 








置 ， 一 个 为 登录 时 用 的 “提交 表单 ”选项 ， 一 个 为 “ 重 设置 单 ” 选 项 ，“ 属 性 ” 四 
的 设置 如 图 4-26 所 示 。 
a 系 
ES PPE wn ogc Oxw ol 

天 于 动作 〇 六) 无 四 mol 下 
户 cn OM) 
证 


4-26 ”设置 按钮 名 称 


在 第 5 行 输入 “注册 新 用 户 ” 文 本 ,并 设置 一 个 转 到 用 户 注册 页 面 registerphp 
的 链接 对 象 ， 以 方便 用 户 注册 ， 如 图 4-27 所 示 。 


属性 
《INL ”格式 EE) 无 _ 国 美 | 无 v BI 江 注 二 绎 标题 D) 
IC) 无 | 链 拥 00) |resister php YD 有 BE 标 @ ~ 
EE | 
口 于 ”各 下风 ~ 高 如 | 2 标题 外 口 















































4-27 ”建立 链接 


ESD 在 “注册 新 用 户 ” 文 本 后 输入 4 个 空格 ， 接 着 继续 输入 “ 找 回 密码 ”文本 ， 
并 设置 一 个 转 到 密码 查询 页 面 lostpassword.php 的 链接 对 象 ， 方 便 用 户 取 回 密码 ， 





















































如 图 4-28 所 示 。 
属性 
[yaL| 格式 四 [无 EF 类 | 无 YBI 开导 二 绍 标题 D) 
即 css 瑟 加 无 局 | 链接 QL) |1ostpassword php ~ 局。 上 姑 @ 辣 
台 三 | 单元 格 。 水 平 四 | 默认 YY 寓 四 不 换行 @) 口 ”背景 颜色 (G) 厂 -| [页面 属性 .. 
































El 委 直 四 | 默认 ~ 高炉 | 2 标题 到 ) 口 





4-28 ”密码 查询 设置 


EC 表单 编辑 完成 后 ， 下 面 来 编辑 该 网 页 的 动态 内 容 ， 使 用 户 可 以 通过 该 网 页 中 
表单 的 提交 实现 登录 功能 。 打 开 “ 服 务 器 行为 ”面板 ， 单 击 该 面板 上 的 “添加 服 
务 器 行为 ”按钮 [区 ， 选 择 “ 用 户 身份 验证 ”一 “登录 用 户 ”， 如 图 4-29 所 示 ， 向 
该 网 页 添加 “登录 用 户 ” 的 服务 器 行为 。 
弹出 “登录 用 户 ” 对 话 框 ， 各 项 参数 的 设置 如 图 4-30 所 示 。 
该 对 话 框 中 ， 各 项 设置 的 作用 如 下 : 
@ ”从 “从 表单 获取 输入 ”下 拉 列 表 框 中 选择 该 服务 器 行为 使 用 网 页 中 的 forml 
对 象 ， 设 定 该 用 户 登录 服务 器 行为 的 用 户 数 据 来 源 为 表单 对 象 中 访问 者 填写 
的 内 容 。 
®@ ”从 “用 户 名 字段 ”下 拉 列 表 框 中 选择 文本 域 usemame 对 象 ， 设 定 该 用 户 登录 
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服务 器 行为 的 用 户 名 数据 来 源 为 表单 的 username 文本 域 中 由 访问 者 所 输入 的 
内 容 。 
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:| password 
welcome Php | BE 
口 转轨 削 一 个 RL( 加 果 它 存在 
如 果 登 录 失 败 ， 转 到 : [Loginfail php [GE 
基于 以 下 项 限制 访问 : @ ”用户 名 和 密码 
名 用 户 各 、 密 码 和 访问 角 别 
获取 级 别 自 : 本 














图 4-30 “登录 用 户 “ 对 话 框 


@ ”从 “密码 字段 ”下 拉 列 表 框 中 选择 文本 域 password 对 象 ， 设 定 该 用 户 登 录 服 
务 器 行为 的 用 户 名 数据 来 源 为 表单 的 password 文本 域 中 访问 者 输入 的 内 容 。 

@ ”从 “使 用 连接 验证 ”下 拉 列 表 框 中 ， 选 择 用 户 登录 服务 器 行为 使 用 的 数据 源 
连接 对 象 为 mymember。 
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@ ”从 “表格 ”下 拉 列 表 框 中 ， 选 择 该 用 户 登录 服务 器 行为 使 用 到 的 数据 库 表 对 
象 为 member。 

从 “用 户 名 列 ” 下 拉 列 表 框 中 , 选择 表 member 存储 用 户 名 的 字段 为 usermame。 
从 “密码 列 ” 下 拉 列 表 框 中 , 选择 表 member 存储 用 户 密码 的 字段 为 password。 
在 “如 果 登 录 成 功 ， 转 到 ”文本 框 中 输入 登录 成 功 后 转向 welcome.php 页 面 。 
在 “如 果 登 录 失败 ， 转 到 ”文本 框 中 输入 登录 失败 后 转向 loginfailphp 页 面 。 
选中 “基于 以 下 项 限制 访问 ”后 面 的 “用 户 名 和 密码 ” 单 选 按钮 ， 设 定 后 面 
将 根据 用 户 的 用 户 名 、 密 码 共同 决定 其 访问 网 页 的 权限 。 
ES 设置 完成 后 ， 单 击 [ 确定 ”| 按钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 在 

“服务 器 行为 ”面板 中 就 增加 了 一 个 “登录 用 户 ” 行 为 ， 如 图 4-31 所 示 。 


服务 器 行为 
十 一 文档 类 型 : PHE 
登录 用 户 


图 4-31 “服务 器 行为 ”面板 
表单 对 象 对 应 的 属性 面板 的 动作 属性 值 为 <?php echo $loginFormAction: ?>， 如 图 4-32 
所 示 。 它 的 作用 就 是 实现 用 户 登录 功能 ， 这 是 一 个 Dreamweaver 自动 生成 的 动作 代码 。 


对 而 可 于 灿 些 洲 内 中 并 瑾 

















到 表单 ID 动作 [php echo $loginFornhetion; ?》 | 局 目标 四 | | 类 四 | 无 EY 
~ 





fornl | 济 法 [POsT ~ 编 码 关 型 











4-32 ”表单 对 应 的 属性 面板 


从 菜单 栏 中 选择 “文件 ”一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 点 中 ， 完 
成 网 站 首页 的 制作 。 


2.2 ”登录 成 功 和 失败 


当 用 户 输入 的 登录 信息 不 正确 时 ， 就 会 转 到 loginfailphp 页 面 ， 显 示 登 录 失败 的 信息 。 

如 果 用 户 输 入 的 登录 信息 正确 ， 就 会 转 到 welcome.php 页 面 。 

(1) 从 菜单 栏 中 选择 “文件 一“ 新建 命令, 在 网 站 根 目录 下 新 建 一 个 名 为 loginfail.php 
的 网 页 并 保存 。 

(2) 登录 失败 页 面 设计 如 图 4-33 所 示 。 在 “文档 ”窗口 中 选中 “这 里 ”文本 ， 在 其 对 
应 的 “属性 ”面板 上 的 “链接 ”文本 框 中 输入 “mindex.php”， 将 其 设置 为 指向 mindex.php 
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页 面 的 链接 。 





和 









































4-33 ”登录 失败 页 面 loginfail.php 


(3) 从 菜单 栏 中 选择 “文件 ”一 “保存 ”命令 ， 完 成 loginfail.php 页 面 的 创建 。 

制作 welcome.php 页 面 ， 详 细 的 制作 步骤 如 下 。 

ECESTDp 从 菜单 栏 中 选择 “文件 ”一 “新 建 ” 命 令 ， 在 网 站 的 根 目录 下 新 建 一 个 名 为 
welcome .php 的 网 页 并 保存 。 

用 类 似 的 方法 制作 登录 成 功 页 面 的 静态 部 分 ， 如 图 4-34 所 示 。 

ES 从 菜单 栏 中 选择 “窗口 ”一 “ 绑 定 ” 命 令 ， 打 开 “ 绑 定 ”面板 ， 单 击 该 面板 
上 的 “添加 绑 定 对 象 ”按钮 [出 | ， 从 弹出 的 快捷 菜单 中 选择 “阶段 变量 ”选项 ， 在 
网 页 中 定义 一 个 阶段 变量 ， 如 图 4-35 所 示 。 





图 4-34 ”欢迎 界面 图 4-35 添加 阶段 变量 


和 注意 :， 阶段 变量 提供 了 一 种 对 象 ， 通 过 这 种 对 象 ， 用 户 信息 得 以 存储 ， 并 使 该 信息 
在 用 户 访问 的 持续 时 间 中 对 应 用 程序 的 所 有 页 都 可 用 。 阶 段 变 量 还 可 以 提供 
一 种 超时 形式 的 安全 对 象 ， 这 种 对 象 在 用 户 账户 长 时 间 不 活动 的 情况 下 ， 终 
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止 该 用 户 的 会 话 。 如 果 用 户 忘记 从 Web 站 点 注销 ， 这 种 对 象 还 会 释放 服务 器 
内 存 和 处 理 资源 。 
EEC 打开 “阶段 变量 ”对 话 框 。 在 “名 称 ”文本 框 中 输入 “阶段 变量 ”的 名 称 
“MM usemame”， 如 图 4-36 所 示 。 

国 于 BY 设置 完成 后 ， 单 击 该 对 话 框 中 的 [__ 确定] 按钮 ， 在 “文档 ”窗口 中 通过 拖 动 
鼠标 选择 “XXXXXX” 文 本 ， 然 后 在 “ 绑 定 ”面板 中 选择 MM usemame 变量 ,再 
单 击 “ 绑 定 ”面板 底部 的 [项 入 _] 按 钮 ， 将 其 插入 到 该 “文档 ”窗口 中 设 定 的 位 置 。 
插入 完毕 ,可 以 看 到 “XXXXXX” 文 本 被 {Session.MM username} 占 位 符 代替 ， 如 
图 4-37 所 示 。 这 样 ， 就 完成 了 这 个 显示 登录 用 户 名 “阶段 变量 ”的 添加 工作 。 


了 而 可 亚 灿 些 洲 峙 中 并 瑾 


阶段 变量 





名 称 : Lusernane 

















图 4-36 “阶段 变量 "对 话 框 图 4-37 ”插入 后 的 效果 


痊 注意 : ”设计 阶段 变量 的 目的 ， 是 在 用 户 登 录 成 功 后 ， 登 录 界 面 中 直接 显示 用 户 的 名 
字 ， 使 网 页 更 有 亲切 感 。 


ED 在 “文档 ”窗口 中 拖 动 鼠 标 ， 选 中 “注销 你 的 用 户 ” 文 本 。 在 “服务 器 行为 ” 
面板 中 单 击 [ 比 | 按 钮 ， 选 择 下 拉 菜 单列 表 中 的 “用 户 身份 验证 ”一 “注销 用 户 ” 命 
令 ， 为 所 选中 的 文本 添加 一 个 “注销 用 户 ” 的 服务 器 行为 ， 如 图 4-38 所 示 。 


Sm Rs as 





Rae 






图 4-38 “注销 用 户 ” 命 令 
弹出 “注销 用 户 ” 对 话 框 。 在 该 对 话 框 中 进行 如 图 4-39 所 示 的 设置 。 
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〇 页面 载 入 





在 完成 后 ， 转 到 : logout. php 








图 4-39 设置 完成 后 的 “注销 用 户 ” 对 话 框 
ESD) 设置 完成 后 ， 单 击 [确定 ”按钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 在 
“服务 器 行为 ”面板 中 增加 了 一 个 “注销 用 户 ” 行 为 ， 同 时 可 以 看 到 “注销 用 户 ” 
链接 文本 对 应 的 “属性 ”面板 中 的 “链接 ”属性 值 为 <?php echo $logoutAction: ?>， 
它 是 Dreamweaver 自动 生成 的 动作 对 象 。 
ED logoutphp 的 页 面 设计 比较 简单 ， 不 做 详细 说 明 ， 在 页 面 中 的 “这 里 ”处 指定 
一 个 链接 到 首页 mindex.php 就 可 以 了 ， 效 果 如 图 4-40 所 示 。 


而 c:\apache\htdocs\sesber\iogout. php (KHTML) -Ox 





Cbody> (RY A lo0% v564xT2v 1K/1 埃 Unicode (UTF-8) 





图 4-40 注销 用 户 页 面 的 设计 效果 


EEJD 从 菜单 栏 中 选择 “文件 ”一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 点 中 。 编 
辑 工作 完成 后 ， 就 可 以 测试 该 用 户 登 录 系 统 的 执行 情况 了 。 文 档 中 的 “修改 您 的 
注册 资料 ”链接 到 userupdate php 页 面 ， 此 页 面 将 在 后 面 进行 介绍 。 


2.3 ”测试 登录 功能 


制作 好 一 个 系统 后 ， 需 要 测试 无 误 ， 才 能 上 传 到 服务 器 中 使 用 。 下 面 就 对 登录 系统 进 
行 测试 ， 测 试 的 步骤 如 下 。 

打开 正 浏览 器 ， 在 地 址 栏 中 输入 “http://127.0.0.1/member/mindex.php”， 打 
开 mindex.php 页 面 ， 如 图 4-41 所 示 。 

划 了 TY 在 “用 户 名 ”和 “密码 ”文本 框 中 输入 用 户 名 及 密码 ， 输 入 完毕 ， 单 击 “ 登 
录 ” 按 钮 。 

ESRS) 如 果 在 第 02 步 中 填写 的 登录 信息 是 错误 的 ， 或 者 根本 就 没有 输入 ， 则 浏览 器 
就 会 转 到 登录 失败 页 面 loginfailphp， 显 示 登 录 错 误 信息 ， 如 图 4-42 所 示 。 

EEC 如 果 输 入 的 用 户 名 和 密码 都 正确 ， 则 显示 登录 成 功 的 页 面 。 这 里 输入 的 是 前 


< 132 


EP 全 时 


面 数 据 库 设 置 的 用 户 admin， 登 录 成 功 后 的 页 面 如 图 4-43 所 示 ， 其 中 显示 了 用 户 
名 admin。 

ED 如 果 想 注销 用 户 ， 只 需要 单 击 “ 注 销 你 的 用 户 ” 超 链接 即 可 。 注 销 用户 后 ， 
浏览 器 就 会 转 到 logoutphp 页 面 ， 然 后 单 击 “ 这 里 ” 回 到 首页 ， 如 图 4-44 所 示 。 
至 此 ， 登 录 功 能 就 测试 完成 了 。 


下 PHP 用 广 管理 和 统 
i @ 错 .日 -回回 砍 甩 枯 言 WRK 全 
ET TT 一 


守 砚 丑 型 特 瞪 淋 须 咀 了 泗 








太 品 % 明 ; 三 星 智 驼 于 机 ,100 万 芝 素 , 广 反 3、 加 4 
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基价 :Yat 

作价 ;2180 


中 兴旺 国产 中 闪 手 机 中 是 新 上 市 的 一 部 智也 ， 


gr 全 括 吉 hnir ol 摧 作 系 坑 ， 且 有 可 入 990WZMY 全 刍 
训 玖 ,内 痊 320 万 从 的 损人 ， 支 联通 cp 
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用 户 注册 资料 修改 


登录 失败 


登录 具 购 ,请 从 查 你 博 写 的 订户 名 的 室友 电 天 正确 


语音 击 这 旦 生 宁 敬 录 ? 











4-42 ”登录 失败 页 面 loginfail.php 的 效果 
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回回 区 





> 
用 户 注册 资料 修改 








图 4-44 单 击 “ 这 里 ” 





二 :| 用 户 注册 功能 


用 户 登 录 系 统 是 为 数据 库 中 已 有 的 老 用 户 登 录用 的 ， 一 个 用 户 管理 系统 还 应 该 提供 新 
用 户 注册 用 的 页 面 ， 对 于 新 用 户 来 说 ， 通 过 单 击 mindex.php 页 面 上 的 “注册 新 用 户 ” 超 链 
接 ， 进 入 到 名 为 register.php 的 页 面 ， 在 该 页 面 可 以 实现 新 用 户 注册 功能 。 


3.1 用 户 注册 页 面 


register.php 页 面 主要 实现 用 户 注 册 的 功能 ， 用 户 注册 的 操作 就 是 向 数据 库 的 member 
表 中 添加 记录 的 操作 ， 完 成 的 页 面 如 图 4-45 所 示 。 
ED 在 网 站 根 目录 下 新 建 一 个 名 为 register.php 的 网 页 ， 插 入 3x1 表格 ， 宽 度 775， 
边框 0， 在 第 一 行 插入 图 片 01.gif， 在 第 三 行 添加 背景 图 片 05.gif。 把 第 二 行 单元 
格 水 平 拆 分 成 两 个 ， 左 边 单元 格 设置 为 宽 179， 高 320， 顶 端 对 齐 ， 添 加 背景 图 片 
02 02.gif。 
EESRDD 在 第 二 行 右边 的 单元 格 中 插入 表单 ， 表 单 内 插入 13x2 表格 ， 表 格 宽 65%， 居 
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[9 
中 对 齐 ， 第 一 列 单元 格 的 宽度 为 24%， 第 二 列 的 宽度 为 76%。 
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图 4-45 用 户 注册 页 面 
ERS) 按 图 4-46 所 示 进 行 表格 内 容 设 计 。 第 一 行 和 最 后 一 行 执行 合并 ， 第 一 行 输入 
文字 “请 用 户 认真 填写 注册 信息 ! ”， 最 后 一 行 插入 两 个 按钮 ，[ 注 册 ] 为 提交 表单 ， 
[ 重 号 ] 为 重 设 表单 ,对 插入 的 各 文本 域 , 依次 在 属性 面板 设置 为 usermame、 password、 
passwordl 、truename、email、tel、QQ、address、answer; 单 选 按钮 均 为 sex( 左 边 
的 值 为 男 ， 已 选中 ， 右 边 的 值 为 女 ， 未 选中 )， 列 表 为 question， 并 设置 不 少 于 3 
项 列表 值 。 在 第 12 行文 本 域 的 右边 单 击 插入 工具 栏 上 的 区 按钮， 插入 隐藏 域 ( 红 
框 标记 的 )， 在 其 属性 面板 设置 隐藏 区 域名 为 authority， 默 认 值 为 0， 即 所 有 的 用 





图 4-46 register.php 页 面 的 静态 设计 
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狂 注意 :在 为 表单 中 的 文本 域 对 象 命名 时 ， 由 于 表单 对 象 中 的 内 容 将 被 添加 到 member 
表 中 ， 可 以 将 表单 对 象 中 的 文本 域名 设置 得 与 数据 库 中 的 相应 字段 名 相同 ， 
这 样 做 的 目的 , 是 当 该 表单 中 的 内 容 添 加 到 member 表 中 时 自动 配对 ,文本 “ 密 
码 验证 ”对 应 的 文本 框 命名 为 password1。 隐 藏 域 是 用 来 收集 或 发 送信 息 的 不 
可 见 元 素 。 对 于 网 页 的 访问 者 来 说 ， 隐 藏 域 是 看 不 见 的 。 当 表单 被 提交 时 ， 
隐藏 域 就 会 将 信息 用 设置 时 定义 的 名 称 和 值 发 送 到 服务 器 上 。 当 用 户 输入 的 
用 户 名 不 存在 时 ， 即 记录 集 Recordsetl 为 空 时 ， 就 会 导致 该 页 面 不 能 正常 显 
示 ， 这 时 就 需要 设置 隐藏 区 域 。 
EEC 还 需要 设置 一 个 验证 表单 的 动作 ， 用 来 检查 访问 者 在 表单 中 填写 的 内 容 是 否 
满足 数据 库 表 member 中 字段 的 要 求 。 在 将 用 户 填 写 的 注册 资料 提交 到 服务 器 之 
前 ， 会 先 对 用 户 填 写 的 资料 进行 验证 ， 如 果 有 不 符合 要 求 的 信息 ， 可 以 向 访问 者 
显示 错误 的 原因 ， 并 让 访问 者 重新 输入 。 
本 于 从 菜单 栏 中 选择 “窗口 ”一 “服务 器 行为 ”命令 ， 则 会 打开 “服务 器 行为 ” 
面板 。 单 击 “ 服 务 器 行为 ”面板 中 的 “添加 服务 器 行为 ”按钮 [ 岂 ， 从 打开 的 行为 
列表 中 选择 “检查 表单 ”， 弹 出 “检查 表单 ”对 话 框 ， 如 图 4-47 所 示 。 


























可 接受 : @O 任何 东西 。 ” 〇 数字 
〇 ”电子 邮件 地 址 “ 〇 数字 从 





图 4-47 设置 “检查 表单 ”对 话 框 


3% 注意 : ”本 例 中 设置 username 文本 域 、password 文本 域 、password1 文本 域 、answer 文 
本 域 、truename 文本 域 、address 文本 域 为 “ 值 :必需 的 ”、“ 可 接受 :任何 东西 ， 
即 这 几 个 文本 域 必 须 填写 ， 内 容 不 限 ， 但 不 能 为 空 ; tel 文本 域 和 qq 文本 域 设 
置 的 验证 条 件 为 “ 值 :必需 的 ”、“ 可 接受 :数字 ”， 表 示 这 两 个 文本 域 必须 填 
写 数 字 ， 不 能 为 空 ，e-mail 文本 域 的 验证 条 件 为 “ 值 :必需 的 ”、“ 可 接受 : 电 
子 邮件 地 址 ”， 表 示 该 文本 域 必须 填写 电子 邮件 地 址 ， 且 不 能 为 空 。 


ET 设置 完成 后 ， 单 击 [_ 确定 “| 按钮 ， 完 成 对 检查 表单 的 设置 。 
EU 在 “文档 ”窗口 中 单 击 工具 栏 上 的 [代码 | 按钮 ， 转 到 代码 编辑 窗口 ， 然 后 在 验 
证 表单 动作 的 源 代码 中 修改 如 下 的 代码 ， 主 要 是 实现 中 文 汉化 的 功能 : 
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<script type="textjavascript"> 
/宣告 脚本 语言 为 JavaScript 
function MM _validateForm|O{ //v4.0 
if(document.getElementById){ 
var i,p,q,nm,test,num,min,max,errors=",args=MM validateForm.srguments; 
for(i=0;i<(args.length-2);i+=3){ 
test=args[i+2]; 
val-document.getElementById(args[i]); 
if(vaD{ 
nm=valname; 
if((val=val.value)!="){ 
if(test.indexOf isEmail)!=1){ 
p=valindexOf @"); 
if(p<1 lp 一 (vaLlength-D) errors+=' "tam+' 需 要 输入 邮 
/ 关 果 提交 的 部 逢 站 二 表 间 中 不 是 好 箱 答 式 则 显示 为 和 
} else if(test!='R'){ 
nu rseFloat(val); 
iisNaN(vaD) errors+='- '+am+' 需 要 输入 | 
1/ 如果 提交 的 电话 表单 中 不 是 数字 则 显示 为 " as 
if(test.indexOf('inRange’)!=1){ 
p=test.indexOf(:"); 
min=test.substring(8,p); 
max=test.substring(p+]1); 
这 mum<min | max<num) errors+='- ‘tam+' 需 要 输入 的 数字 +min+'and'+max+".\n'; 
/如 果 提 交 的 QQ 表单 中 不 是 数字 则 显示 为 "需要 输入 的 数字 "; 


对 而 可 于 类 些 洲 内 开 开 





} 


} 
} else if(test.charAt(0)—'R’ errors+='- "tgm+' 需 要 输入 .\n'; 


本 ) / 宁 失 去 的 地 直 天 间 为 空 则 显示 学 ' 需 要 输入 "; 
iflerrors) te n'terrors); 
1/ 如果 出 错 则 显示 注册 时 出 现 如 下 
document. MM returnV: le 
} 
} 
</script> 


编辑 代码 完成 后 ， 单 击 工具 栏 上 的 [ 氏 沪 按钮， 返回 到 “文档 ”窗口 。 此 时 ， 可 以 测试 
一 下 执行 的 效果 ， 如 果 没 有 输入 就 单 击 “提交 ”按钮 ， 会 弹出 一 个 提示 信息 框 ， 图 4-48 中 
的 警告 信息 是 告诉 访问 者 需要 输入 相关 的 信息 。 


Hicrosoft Internet Explorer (区 | 





图 4-48 ”提示 信息 框 


ER) 在 该 网 页 中 添加 一 个 “插入 ”的 服务 器 行为 。 在 “服务 器 行为 ”面板 (车 没有 
则 选择 “窗口 ”一 “服务 器 行为 ”菜单 命令 调 出 )， 单 击 面板 上 的 [二 按钮 ， 从 弹出 
的 下 拉 菜单 中 选择 “插入 记录 ”， 如 图 4-49 所 示 ， 会 弹出 “插入 记录 ”对 话 框 。 
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DW xs#w 因 玫 香 加 首相 回 $9 四 区 让 加 DO mo | 








| 忆 记 
人 /而 可 人 由本 加 多 各 二 天 局 二 要 文 失 。 近 三 | 去 入 总 
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[Omm| 并 无 ES 

Bes mg 无 ~ YeD 她 名 
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图 4-49 执行 “插入 记录 ”操作 


ED 在 对 话 框 中 进行 设置 , 并 将 网 页 中 的 表单 对 象 与 数据 库 member 表 中 的 字段 一 
一 对 应 起 来 ， 设 置 完 成 后 ， 该 对 话 框 如 图 4-50 所 示 。 























插入 后 ， 转 到 : |regok. php 











图 4-50 “插入 记录 ”对 话 框 

ED 设置 完成 后 ， 单 击 [确定 “| 按钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 此 
时 的 设计 样式 如 图 4-51 所 示 。 

ES 用 户 名 是 用 户 登 录 的 身份 标志 ， 用 户 名 是 不 能 够 重复 的 ， 所 以 在 添加 记录 之 
前 ， 一 定 要 先 在 数据 库 中 判断 该 用 户 名 是 否 存在 ， 如 果 存 在 ， 则 不 能 进行 注册 。 
在 Dreamweaver 中 提供 了 一 个 检查 新 用 户 名 的 服务 器 行为 ， 单 击 “ 服 务 器 行为 ” 
面板 上 的 [ 节 ] 按 钮 ， 从 弹出 的 菜单 中 ， 选 择 “用 户 身份 验证 ”一 “检查 新 用 户 名 ” 
命令 ， 如 图 4-52 所 示 。 
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4-51 设置 插入 记录 功能 后 的 效果 
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图 4-52 选择 “检查 新 用 户 名 ”命令 


此 时 ,会 弹出 一 个 “检查 新 用 户 名 ”对 话 框 , 在 “用 户 名 字段 ”下 拉 列 表 框 中 选择 usermame 
字段 ， 在 “如 果 已 存在 ， 则 转 到 ”文本 框 中 输入 “regfailphp”。 表 示 如 果 用 户 名 已 经 存在 ， 
则 转 到 regfailphp 页 面 ,显示 注册 失败 信息 ,该 网 页 将 在 后 面 编辑 。 设 置 完 成 后 的 对 话 框 如 
图 4-53 所 示 。 
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用 户 名 字段 : [usernane | 


如 果 已 存在 ， 则 转 到 : resfail php 





图 4-53 “检查 新 用 户 名 ”对 话 框 


EC 设置 完成 后 ， 单 击 该 对 话 框 中 的 [_ 弄 定 _] 按 钮 ， 关 闭 该 对 话 框 ， 返 回 到 “ 文 
档 ” 窗 口 。 在 “服务 器 行为 ”面板 中 增加 了 一 个 “检查 新 用 户 名 ”的 行为 ， 再 从 
菜单 栏 中 选择 “文件 ”一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 点 中 ， 从 而 完成 
了 本 页 的 制作 。 


3.2 ”注册 成 功 和 失败 


为 了 方便 用 户 登 录 , 应 该 在 regok.php 页 面 中 设置 一 个 转 到 mindex.php 页 面 的 文字 链接 ， 
以 方便 用 户 进行 登录 。 同 时, 为 了 方便 访问 者 重新 进行 注册 ， 则 应 该 在 regfail.php 页 面 设置 
一 个 转 到 register.php 页 面 的 文字 链接 ， 以 方便 用 户 进行 重新 登录 。 这 里 将 制作 显示 注册 成 
功 和 失败 的 页 面 。 
EEC 从 菜单 栏 中 选择 “文件 ”一 “新 建 ” 命 令 ， 在 网 站 根 目录 下 新 建 一 个 名 为 
“regok.php” 的 网 页 并 保存 。 
ED regokphp 页 面 如 图 4-54 所 示 。 制 作 比 较 简 单 ， 其 中 将 “这 里 ”文本 设置 为 指 
向 mindex.php 页 面 的 链接 。 
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图 4-54 注册 成 功 时 使 用 的 regok.php 页 面 
如 果 用 户 输入 的 注册 信息 不 正确 ， 或 用 户 名 已 经 存在 ， 则 应 该 向 用 户 显示 注 
册 失 败 的 信息 。 这 里 再 新 建 一 个 regfail php 页 面 ， 该 页 面 的 设计 如 图 4-55 所 示 。 
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其 中 将 “这 里 ”文本 设置 为 指向 registerphp 页 面 的 链接 。 
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图 4-55 注册 失败 时 使 用 的 regfail.php 页 面 


3.3 ”注册 功能 的 测试 


设计 完成 后 ， 就 可 以 测试 该 用 户 注册 功能 的 执行 情况 了 。 
打开 正 浏览 器 ， 在 地 址 栏 中 输入 “http://127.0.0.1/member/register.php”， 打 
开 register.php 文件 ， 如 图 4-56 所 示 。 


vk 
用 户 注册 资料 修改 


请 用 户 认真 填写 注册 信息 ! 
PP 各 : 











图 4-56 打开 的 测试 页 面 
可 以 在 该 注册 页 面 中 输入 一 些 不 正确 的 信息 ， 如 漏 填 username、password 等 
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必 填 字段 ， 或 填写 非法 的 E-mail 地 址 ， 或 在 确认 密码 时 两 次 输入 的 密码 不 一 致 ， 
以 测试 网 页 中 验证 表单 动作 的 执行 情况 。 如 果 填 写 的 信息 不 正确 ， 则 浏览 器 应 该 
打开 提示 信息 框 , 向 访问 者 显示 错误 原因 , 如 图 4-57 所 示 是 一 个 提示 信息 框 示例 。 





4-57 ”出错 提示 


EEOE 在 该 注册 页 面 中 注册 一 个 已 经 存在 的 用 户 名 ， 如 输入 “design”， 用 来 测试 新 
用 户 服务 器 行为 的 执行 情况 。 然 后 单 击 [确定 _] 按 钮 ， 此 时 ， 由 于 用 户 名 已 经 存 
在 ， 浏 览 器 会 自动 转 到 regfail.php 页 面 ， 如 图 4-58 所 示 ， 告 诉 访问 者 该 用 户 名 已 
经 存在 。 此 时 ,访问 者 可 以 单 击 “ 这 里 ”链接 文本 ， 返 回 register.php 页 面 ， 以 便 
重新 进行 注册 。 


不 好 意思 ,你 注册 的 用 户 名 已 经 被 注册 


请 单 击 这 里 重新 注册 4 





图 4-58 注册 失败 时 页 面 的 显示 


ES 在 该 注册 页 面 中 填写 正确 的 注册 信息 。 单 击 [__ 确定] 按钮 。 由 于 这 些 注册 资 
料 完全 正确 ， 而 且 这 个 用 户 名 没有 重复 。 浏 览 器 会 转 到 regok.php 页 面 ， 向 访问 者 
显示 注册 成 功 的 信息 ， 如 图 4-59 所 示 。 此 时 ,访问 者 可 以 单 击 “这 里 ”链接 文本 ， 
转 到 mindex.php 页 面 ， 以 便 进 行 登录 。 
在 MySQL 中 打开 用 户 数 据 库 文件 member， 查 看 其 中 的 member 表 对 象 的 内 容 。 此 时 
可 以 看 到 ， 在 该 表 的 最 后 创建 了 一 条 新 记录 ， 其 中 的 数据 就 是 刚才 在 网 页 registerphp 中 提 
交 的 注册 用 户 的 信息 ， 如 图 4-60 所 示 。 
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图 4-59 注册 成 功 页 面 
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4-60 表 member 中 添加 了 一 条 新 记录 


至 此 ， 基 本 上 完成 了 用 户 管理 系统 中 注册 功能 的 开发 和 测试 。 在 制作 的 过 程 中 ， 可 以 
根据 制作 网 站 的 需要 ， 适 当 加 入 其 他 更 多 的 注册 文本 域 ， 也 可 以 给 需要 注册 的 文本 域名 称 
部 分 添加 星 号 (*)， 提 醒 注册 用 户 注意 。 


国 ] 4| 修改 用 户 资料 


修改 注册 用 户 资料 的 过 程 ， 就 是 往 用 户 数据 表 中 更 新 记录 的 过 程 ， 本 任务 重点 介绍 如 
何在 用 户 管理 系统 中 实现 用 户 资料 的 修改 功能 。 


4.1 修改 资料 的 页 面 


该 页 面 主 要 把 用 户 的 所 有 资料 都 列 出 ， 通 过 “更 新 记录 ”命令 实现 资料 修改 的 功能 。 

有 具体 的 制作 步骤 如 下 。 
ES 修改 资料 的 页 面 和 用 户 注册 页 面 的 结构 十 分 相似 ， 可 以 通过 对 register.php 页 
面 的 修改 来 快速 得 到 所 需要 的 记录 更 新 页 面 。 打 开 registerphp 页 面 ， 从 菜单 栏 中 
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选择 “文件 ”一 “另存 为 ”命令 ， 将 该 文档 另存 为 userupdatephp， 并 在 第 一 行 加 
入 如 下 代码 : 
<?php 
session start(); 
?> // 启 动 Session 环境 
ETI> 从 菜单 栏 中 选择 “窗口 ”一 “服务 器 行为 ”命令 ， 打 开 “ 服 务 器 行为 ”面板 。 
在 “服务 器 行为 ”面板 中 删除 全 部 的 服务 器 行为 并 修改 其 相应 的 文字 ， 该 页 面 修 
改 完成 后 ， 显 示 效 果 如 图 4-61 所 示 。 


EBT - 了 crzoft Internet Exzplorer 
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4-61 userupdate.php 静态 页 面 


ES 从 菜单 栏 中 选择 “窗口 ”一 “ 绑 定 ” 命 令 ， 打 开 “ 绑 定 ”面板 ， 单 击 该 面板 
上 的 [大 按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “记录 集 (查询 )” 选 项 ， 则 会 打开 “记录 
集 ” 对 话 框 。 在 该 对 话 框 中 进行 如 下 设置 : 

@ 在 “名 称 ” 文 本 框 中 输入 “upuser” 作 为 该 记录 和 集 的 名 称 。 

在 “连接 ”下 拉 列 表 框 中 选择 user 数据 源 连接 对 象 为 “mymember”。 

在 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 “member”。 

在 “ 列 ” 单 选 按 钮 组 中 选中 “全 部 ” 单 选 按 钮 。 

在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 为 “usermame” 一 “=” 一 “阶段 变量 ” 

一 “MM Usermame”。 

完成 后 的 设置 如 图 4-62 所 示 。 

EC 设置 完成 后 ， 单 击 该 对 话 框 上 的 [__ 确定 按钮， 完成 记录 集 的 绑 定 。 

完成 记录 集 的 绑 定 后 ， 将 upuser 记录 集中 的 字段 绑 定 到 页 面相 应 的 位 置 上 ， 
注意 插入 一 个 隐藏 域 为 ia， 设置 在 用 户 名 字段 的 后 面 ， 如 图 4-63 所 示 。 
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4-62 ”定义 upuser 记录 集 
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4-63 ” 绑 定 动态 内 容 后 的 userupdate.php 页 面 


对 于 网 页 中 的 单 选 按钮 组 sex 对 象 , 绑 定 动态 数据 可 以 按照 如 下 方法 。 单 击 “ 服 
务 器 行为 ”面板 上 [i 按钮 ， 从 弹出 的 下 拉 菜 单 中 ， 执 行 “动态 表单 元 素 ” 一 “ 动 
态 单 选 按钮 ”命令 ， 设 置 动态 单 选 按钮 组 对 象 。 打 开 “ 动 态 单 选 按钮 组 ”对 话 框 。 
从 “ 单 选 按钮 组 ”下 拉 列 表 框 中 选择 forml 表单 中 的 单 选 按钮 组 sex。 单 击 “ 选 取 
值 等 于 ”文本 框 后 面 的 田 按 钮 ， 从 弹出 的 “动态 数据 ”对 话 框 中 选择 记录 集 upuser 
中 的 sex 字段 ， 同 样 对 提问 的 问题 列表 进行 动态 绑 定 ， 如 图 4-64 所 示 。 

动态 单 选 按 钮 组 


但 组 :ex 下 家 和 “Eom” 一 





选取 值 等 于 : |<?php echo $rov_upuser[ sex | 国 











图 4-64 设置 “动态 单 选 按钮 组 ”对 话 框 
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ED 单 击 “ 服 务 器 行为 ”面板 上 [ 鸭 | 按钮 ， 从 弹出 的 下 拉 菜单 中 选择 “更 新 记录 ” 
选项 ， 为 网 页 添加 更 新 记录 的 服务 器 行为 ， 如 图 4-65 所 示 。 


DW 文件 中 机 后 天 电表 四 人 田 本 四 交加 站 加 全 四 神 加 
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[Gm] | WO CE 1 三 本 
并 cs WW 于 ~ TOD 上 四 
[ERt _  ) 




















图 4-65 选择 “更 新 记录 ”选项 
ED) 弹出 “更 新 记录 ”对 话 框 ， 该 对 话 框 与 插入 记录 的 对 话 框 十 分 相似 ， 有 具体 的 
设置 情况 如 图 4-66 所 示 ， 这 里 不 再 重复 。 











提交 值 ， 目 : | fernl 
连接 : | 











提交 为 : | 整数 
在 更 新 后 ， 转 到 : userupdateok. php 

















图 4-66 “更 新 记录 ”对 话 框 
国 于 BY 设置 完成 后 ， 单 击 [_ 厂 按钮 ， 关闭 该 对 话 框 ， 返回 到 “文档 ”窗口 。 再 从 
菜单 栏 中 选择 “文件 ”一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 点 中 。 


胃 注意 : ”由 于 本 页 的 MM Username 值 是 来 自 上 一 页 注册 成 功 后 的 用 户 名 值 , 所 以 单独 
测试 是 会 提示 出 错 的 ， 要 先 登录 后 ， 在 登录 成 功 页 面 单 击 “ 修 改 您 的 注册 资 
料 ” 超 链接 到 该 页 面 才 会 产生 效果 ， 这 在 后 面 的 测试 实例 中 将 进行 介绍 。 
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4.2 更 新 成 功 页 面 


用 户 修改 注册 资料 成 功 后 ， 就 会 转 到 userupdateok php。 在 该 网 页 中 ， 应 该 向 用 户 显示 
资料 修改 成 功 的 信息 。 除 此 之 外 ， 还 应 该 考虑 两 种 情况 : 如 果 用 户 要 继续 修改 资料 ， 则 为 
其 提供 一 个 返回 到 userupdate php 页 面 的 超 文 本 链接 : 如果 用 户 不 需要 修改 ， 则 为 其 提供 一 
个 转 到 用 户 登录 页 面 mindex.php 页 面 的 超 文本 链接 。 具 体 的 制作 步骤 如 下 。 

EEC 从 菜单 栏 中 选择 “文件 ”一 “新 建 ”命令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 

userupdateok.php 的 网 页 并 保存 ， 在 第 一 行 加 入 如 下 代码 : 


<?php 
session start(); 


?> ”// 启 动 Session 环境 


ED 为 了 向 用 户 提供 更 加 友好 的 界面 ， 应 该 在 网 页 中 显示 用 户 修改 的 结果 ， 以 供 
用 户 检查 修改 是 否 正 确 。 我 们 应 该 首先 定义 一 个 记录 集 ， 然 后 将 绑 定 的 记录 集 插 
入 到 网 页 中 相应 的 位 置 ， 其 方法 跟 制 作 页 面 userupdate .php 中 的 方法 一 样 。 通 过 在 
表格 中 添加 记录 集中 的 动态 数据 对 象 ， 把 用 户 修改 后 的 信息 显示 在 表格 中 ， 这 里 
不 做 详细 说 明 ， 可 参考 前 面 的 内 容 ， 最 终结 果 如 图 4-67 所 示 。 


半 克 加 弄 特 瞪 淋 须 咀 卫 泗 
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图 4-67 更 新 成 功 时 的 页 面 


4.3 ”修改 资料 测试 


编辑 工作 完成 后 ， 就 可 以 测试 该 修改 资料 功能 的 执行 情况 了 ， 测 试 的 步骤 如 下 。 
打开 正 浏览 器 ， 在 地 址 栏 中 输入 “http://127.0.0.1/member/mindex.php”， 打 
开 mindex.php 文件 。 在 该 页 面 中 进行 登录 。 登 录 成 功 后 ， 进 入 welcome.php 页 面 ， 
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在 welcome.php 页 面 单 击 “修改 您 的 资料 ” 超 链接 ， 转 到 userupdate php 页 面 ， 如 
图 4-68 所 示 。 


诺 -一 
用 户 登录 用 户 注册 资料 修改 


请 用 户 认真 修改 注册 信息 
六 


未 后 是 :你 量 好 的 朋友 是 ? ~ 
要 








4-68 ”修改 design 用 户 注册 资 料 


EEJRPy 在 该 页 面 中 进行 一 些 修改 ， 然 后 单 击 “提交 ”按钮 ， 将 修改 结果 发 送 到 服务 
器 中 。 当 用 户 记录 更 新 成 功 后 ， 浏 览 器 会 转 到 userupdateok.php 页 面 中 ， 显 示 修 改 
资料 成 功 的 信息 ， 同 时 还 显示 该 用 户 修 改 后 的 资料 信息 ， 并 提供 转 到 更 新 成 功 页 
面 和 转 到 主页 面 的 链接 对 象 ， 这 里 对 “真实 姓名 ”进行 了 修改 ， 单 击 “修改 ” 按 
钮 转 到 更 新 成 功 页 面 ， 效 果 如 图 4-69 所 示 。 


一 
用 户 注册 资料 修改 








图 4-69 更 新 成 功 
上 述 测试 结果 表明 ， 用 户 修改 资料 页 面 已 经 制作 成 功 。 


NA 











模 

块 

国 5| 查询 密码 功能 图 
管 

用 户 注册 页 面 通常 会 设计 问题 和 答案 文本 框 ， 它 们 的 作用 是 当 用 户 忘记 密码 时 ， 可 以 
通过 这 个 问题 和 答案 到 服务 器 中 找 回 遗失 的 密码 。 实 现 的 方法 是 判断 用 户 提供 的 答案 与 数 三 
据 库 中 的 答案 是 否 相 同 ， 如 果 相 同 ， 则 可 以 找 回 遗失 的 密码 。 
设 

5.1 查询 密码 页 面 计 


本 节 主 要 制作 密码 查询 页 面 lostpassword.php， 具 体 的 制作 步骤 如 下 。 

EEC 从 菜单 栏 中 选择 “文件 ”一 “新 建 ” 命 令 ， 然 后 在 网 站 的 根 目录 下 新 建 一 个 
名 为 “lostpassword.php” 的 网 页 文件 并 保存 。lostpassword.php 页 面 是 用 来 让 用 户 
提交 要 查询 的 遗失 密码 的 用 户 名 的 页 面 ， 该 网 页 的 结构 比较 简单 ， 设 计 后 的 效果 
如 图 4-70 所 示 。 


邮 cnpache lntdocs member)iostpassmerd php (XRTEL) 
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图 4-70 lostpassword.php 页 面 


EDp 在 “文档 ”窗口 中 选中 表单 对 象 ， 找 到 其 对 应 的 “属性 ”面板 ， 在 “表单 名 
称 ” 文 本 框 中 输入 “form1”， 在 “动作 ”文本 框 中 输入 “showquestion.php” 作 为 
该 表单 提交 的 对 象 页 面 。 在 “方法 ”下 拉 列 表 框 中 选择 POST 作为 该 表单 的 提交 
方式 ， 接 下 来 ， 将 输入 用 户 名 的 文本 域 命名 为 “inputname”， 如 图 4-71 所 示 。 

其 中 ， 表 单 属 性 设置 面板 中 的 主要 选项 作用 如 下 。 

在 “表单 ID” 文 本 框 中 输入 标志 该 表单 的 唯一 名 称 ， 命 名 表单 后 ， 就 可 以 使 用 脚本 语 


149 > 


PHP+MySQL 
动态 网 站 设计 恨 用 教程 


言 引用 或 控制 该 表单 了 。 如 果 不 命名 表单 ， 则 Dreamweaver 使 用 语法 forml、form2、... 生 
成 一 个 名 称 ， 并 在 向 页 面 中 添加 每 个 表单 时 递增 n 的 值 。 


属性 


站 | 表单 也 
加 Eorml 








showauestion php 已 目标 四 问 ， 类 加 | 无 EA 
FT ~ 编 四 类 型 加 
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加 文本 域 字符 宽度 外 类 型 @ 单 行 G) 。 口 多 行 轨 。 口 意 码 四 美加 | 无 
inputnane 最 多 字符 数 初始 值 CI) | 过 
口 林 用 四 ) 


口 R 读 @@) 






































4-71 设置 表单 提交 的 动态 属性 


在 “方法 ”下 拉 列 表 框 中 , 选择 将 表单 数据 传输 到 服务 器 的 方法 。 POST 方法 将 在 HITP 
请 求 中 嵌入 表单 数据 。GET 方法 将 表单 数据 附加 到 请 求 该 页 面 的 URL 中 ， 是 默认 设置 , 但 
其 缺点 是 表单 数据 不 能 太 长 ， 所 以 本 例 选择 POST 方法 。 

而 “目标 ”下 拉 列 表 框 用 于 指定 返回 窗口 的 显示 方式 ， 各 目标 值 含义 如 下 。 

_blank: 在 未 命名 的 新 窗口 中 打开 目标 文档 。 

@ _parent: 在 显示 当前 文档 的 窗口 的 父 窗口 中 打开 目标 文档 。 

@ self: 在 提交 表单 所 使 用 的 窗口 中 打开 目标 文档 。 

@ top: 在 当前 窗口 的 窗 体内 打开 目标 文档 。 此 值 可 用 于 确保 目标 文档 占用 整个 窗口 ， 

即 让 原始 文档 显示 在 框架 中 。 
用 户 在 lostpassword.php 页 面 中 输入 用 户 名 ， 并 单 击 “ 提 交 ” 按 钮 后 ， 会 通过 表单 将 用 
户 名 提交 到 showquestion.php 页 面 中 , 该 页 面 的 作用 是 根据 用 户 名 从 数据 库 中 找到 对 应 的 提 
示 问 题 并 显示 在 showquestion .php 页 面 中 ， 使 用 户 可 以 在 该 页 面 中 输入 问题 的 答案 。 
下 面 就 制作 显示 问题 的 页 面 。 
ESRS) 新 建 一 个 文档 。 设 置 好 网 页 属性 后 ， 输 入 网 页 标题 “查询 问题 ”， 从 菜单 栏 
中 选择 “文件 ”一 “保存 ”命令 ， 将 该 文档 保存 为 “showquestion php”。 

在 Dreamweaver 中 制作 静态 网 页 ， 完 成 后 的 效果 如 图 4-72 所 示 。 

国 于 BY 在 “文档 ”窗口 中 选中 表单 对 象 ， 定 位 到 “属性 ”面板 ， 在 “动作 ”文本 
框 中 输入 “showpassword.php” 作 为 该 表单 提交 的 对 象 页 面 。 在 “方法 ”下 拉 列 表 
框 中 选择 POST 表单 提交 方式 ， 如 图 4-73 所 示 。 将 输入 密码 提示 问题 答案 的 文本 
域 命 名 为 “inputanswer”。 

ED 从 菜单 栏 中 选择 “窗口 ”一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ” 面 板 ， 单 击 该 面板 
上 的 [| 按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “记录 集 (查询 )” 选 项 ， 打 开 “ 记 录 集 ” 
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4-72 ”showquestion. php 的 静态 设计 


















































加 文本 域 字符 宽度 名 类 型 中 单行 @) 。” 口 多 行 。 〇 省 码 中 业 @ 无 ” 
linputanswer 最 多 字符 数 | 初始 值 0D ] 多 
口 本 用 @) 
口 R 读 @) 


4-73 ”设置 表单 提交 的 属性 


EEC 在 “记录 集 ” 对 话 框 中 进行 如 下 设置 : 
@ 在 “名 称 ” 文 本 框 中 输入 “Recordset1” 作 为 该 记录 集 的 名 称 。 
@ ”从 “连接 ”下 拉 列 表 框 中 选择 数据 源 连接 对 象 为 “mymember”。 
@ ”从 “表格 ”下 拉 列 表 框 中 选择 使 用 的 数据 库 表 对 象 为 “member”。 
@ ”在 “ 列 ” 栏 中 选中 “ 选 定 的 ” 单 选 按钮 ,然后 从 下 拉 列 表 框 中 选择 “usemame” 
和 “question”。 
e@ ”在 “筛选 ” 栏 中 ,设置 记录 集 过 滤 的 条 件 为 “usemame” 一 “=” 一 “表单 变 
量 ” 一 “inputname”， 表 示 根 据 数据 库 中 的 username 字段 的 内 容 是 否 与 从 上 
一 个 网 页 的 表单 中 的 inputname 表单 对 象 传递 过 来 的 信息 完全 一 致 , 来 过 滤 记 
录 对 象 。 
完成 后 的 设置 如 图 4-74 所 示 。 
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名 称 : Recordset1 





:|mymember v 


连接 
表格 : member 
列 
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:O 全 部 ”加 选 定 的 : 
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inputnane 
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图 4-74 “记录 集 ” 对 话 框 
EEC 设置 完成 后 ， 单 击 该 对 话 框 上 的 [_ 确定] 按钮 ， 关 闭 该 对 话 框 ， 返 回 到 “ 文 


档 ”窗口 。 
将 Recordsetl 记录 集中 的 question 字段 绑 定 到 页 面 上 相应 的 位 置 ， 如 图 4-75 
所 示 。 


coache\ htdocs sesber\ihovauestion shop (KHTML) -Ox 
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图 4-75 绑 定 字段 


EC 从 菜单 栏 中 选择 “插入 ”一 “表单 ”一 “隐藏 域 ”命令 ， 在 表单 中 插入 一 个 
表单 隐藏 域 ， 然 后 将 该 隐藏 域 的 名 称 设置 为 “usemame”。 


国 对 项 


ED 选中 该 隐藏 域 ， 转 到 “ 绑 定 ”面板 ， 将 Recordsetl 记录 集中 的 usermame 字段 
绑 定 到 该 表单 隐藏 域 中 ， 如 图 4-76 所 示 。 


记录 集 (Recordset1) 


username 


question 
田 潮 Session 


半 克 丑 型 特 瞪 淋 须 呆 卫 性 


格式 无 习 


代码 ;| <?php echo $row_Recordsetl[’ usem 





4-76 添加 表单 隐藏 域 


普 注意 : 当 用 户 输入 的 用 户 名 不 存在 时 ， 即 记录 集 Recordsetl 为 空 时 ， 就 会 导致 该 页 面 
不 能 正常 显示 ， 这 就 需要 设置 隐藏 区 域 。 
EGGDP) 在 “文档 ”窗口 中 选中 当 用 户 输入 用 户 名 存在 时 显示 的 内 容 即 整个 表单 ， 然 
后 单 击 “ 服 务 器 行为 ”面板 上 的 [ 鸭 按 钮 ， 从 弹出 的 下 拉 菜单 中 选择 “显示 区 域 ” 
一 “如 果 记 录 集 不 为 空 则 显示 区 域 ”， 则 会 打开 “如 果 记 录 集 不 为 空 则 显示 ”对 
话 框 ， 在 该 对 话 框 中 选择 记录 集 对 象 为 “Recordsetl ”。 这 样 ， 只 有 当 记录 集 
Recordsetl 不 为 空 时 , 才 显 示 出 来 , 如 图 4-77 所 示 。 设置 完成 后 , 单 击 [确定 “| 按 
钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 


如 果 记 录 集 不 为 空 则 显示 























图 4-77 “如 果 记 录 集 不 为 空 则 显示 ”对 话 框 
EGRE) 在 网 页 中 编辑 显示 用 户 名 不 存在 时 的 文本 “该 用 户 名 不 存在 ! ”， 并 为 这 些 
内 容 设置 一 个 “如 果 记 录 集 为 空 则 显示 区 域 ”的 隐藏 区 域 服务 器 行为 ， 这 样 ， 当 
记录 集 Recordsetl 为 空 时 ， 就 显示 这 些 文本 ， 完 成 后 的 网 页 如 图 4-78 所 示 。 
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图 4-78 设置 隐藏 区 域 
5.2 ”完善 查询 功能 


当 用 户 在 showquestion.php 页 面 中 输入 答案 ， 单 击 “ 提 交 ” 按 钮 后 ， 服 务 器 就 会 把 用 户 
名 和 密码 提示 问题 答案 提交 到 showpassword.php 页 面 中 。 
下 面 介绍 如 何 设计 该 页 面 ， 具 体制 作 步 骤 如 下 。 
选择 “文件 ”一 “新 建 ” 菜 单 命令 ， 在 网 站 的 根 目录 下 新 建 一 个 名 为 
“showpassword.php” 的 网 页 并 保存 。 


在 Dreamweaver 中 ， 使 用 提供 的 制作 静态 网 页 的 工具 完成 如 图 4-79 所 示 的 静 
态 部 分 。 











TEST 0 | 


[hody) Ctabley tr> CD > = 











4-79 showpassword.php 页 面 的 静态 设计 
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国 对 项 


四 BY> 从 菜单 栏 中 选择 “窗口 ”一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ”面板 ， 单 击 该 面板 
上 [按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “记录 集 ( 查 询 )” 选 项 ， 则 会 打开 “记录 集 ” 
在 该 对 话 框 中 进行 如 下 设置 : 
在 “名 称 ” 文 本 框 中 输入 “Recordsetl ”作为 该 记录 和 集 的 名 称 。 
从 “连接 ”下 拉 列 表 框 中 ， 选 择 数据 源 连 接 对 象 mymember。 
从 “表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 member。 
在 “ 列 ? 栏 中 , 先 选择 “ 选 定 的 单 选 按钮 , 然后 选择 字段 列表 框 中 的 usemame、 
password 和 answer 这 3 个 字段 就 行 了 。 
@ 在 “筛选 ” 栏 中 设置 记录 集 过滤 的 条 件 为 “answer” 一 “=” 一 “表单 变量 ” 
一 “inputanswer”， 表 示 将 会 根据 数据 库 中 answer 字段 的 内 容 是 否 与 从 上 一 
个 网 页 的 表单 中 的 inputanswer 表单 对 象 传递 过 来 的 信息 完全 一 致 ， 来 过 滤 记 
录 对 象 。 
完成 后 的 设置 情况 如 图 4-80 所 示 。 


了 而 可 亚 类 些 洲 内 开 开 





: [nymenber 


: |member 


















































图 4-80 设置 “记录 集 ” 对 话 框 
ED 单 击 [_ 克 按钮， 关闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 
将 记录 集 的 username 和 password 字段 分 别 添加 到 网 页 中 ， 如 图 4-81 所 示 。 
同样 需要 根据 记录 集 Recordsetl 是 否 为 空 ， 为 该 网 页 中 的 内 容 设置 隐藏 区 域 
的 服务 器 行为 。 在 “文档 ”窗口 中 ， 选 中 当 用 户 输入 密码 提示 问题 答案 正确 时 显 
示 的 内 容 ， 然 后 单 击 “ 服 务 器 行为 ”面板 上 的 “添加 服务 器 行为 ”[ 鸭 按钮 ， 从 弹 
出 的 下 拉 菜 单 中 执行 “显示 区 域 ” 一 “如 果 记 录 集 不 为 空 则 显示 区 域 ”命令 ， 打 
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开 “ 如 果 记 录 集 不 为 空 则 显示 ”对 话 框 ， 在 该 对 话 杠 中， 选择 记录 集 对 象 为 
“Recordsetl”。 这 样 ， 只 有 当 记 录 集 Recordsetl 不 为 空 时 , 才 显 示 出 来 , 如 图 4-82 
所 示 。 设 置 完成 后 ， 单 击 [_ 确定 ”| 按钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 


国 c:Wpachevhtdocsveeabervshowpassvord php (Enajs 


EAE nymenber php 














i 
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| 
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oayy Kabley Cr > Cay > [UG oor ve x dv 7K/ 11 WD Wnicods (WF-6) 





4-81 ”加 入 的 记录 集 字段 效果 








4-82 “如 果 记 录 集 不 为 空 则 显示 ”对 话 框 


EGR 在 网 页 中 选择 当 用 户 输入 密码 提示 问题 答案 不 正确 时 显示 的 内 容 ， 并 为 这 些 
内 容 设置 一 个 “如 果 记 录 集 为 空 则 显示 区 域 ” 的 隐藏 区 域 服务 器 行为 ， 这 样 ， 当 
记录 集 Recordset] 为 空 时 ， 将 会 显示 这 些 文本 ， 如 图 4-83 所 示 。 


如 果 记 录 集 为 空 则 显示 




















图 4-83 “如 果 记 录 集 为 空 则 显示 ”对 话 框 


EESe) 完成 后 的 网 页 如 图 4-84 所 示 。 从 菜单 栏 中 选择 “文件 ”一 “保存 ”命令 ， 将 
该 文档 保存 到 本 地 站 点 中 。 
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国 叶 车 


cpache\ htdocs\nesber lshorpassrord shp (HL) -Ox 









对 而 可 于 类 些 洲 内 中 并 瑾 
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(dody> NO 100x Jee0 x 49rv 78 K 7 12 Unicode (TP-0) 











4-84 ”完成 后 的 网 页 效果 


5.3 ”查询 密码 功能 


开发 完成 查询 密码 的 功能 后 ， 就 可 以 测试 执行 的 情况 了 ， 进 行 测试 的 步 又 如 下 。 

ED 启动 浏览 器 ， 在 地 址 中 输入 “http://127.0.0.1/member/mindex.php”， 打 开 
mindex.php 首页 ， 单 击 该 页 面 中 的 “ 找 回 密码 ” 超 链 接 ， 进 入 找 回 密码 页 面 ， 
如 图 4-85 所 示 。 


国 :wpache\htdoesvaeaber\iostpasavord php (rm ) 

















3 
[VIA GO “16502437 EI Unicode ne | 








图 4-85 输入 要 查询 的 用 户 名 
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当 用 户 进 入 密码 查询 页 面 lostpassword.php 后 ， 可 以 输入 并 向 服务 器 提交 自己 
注册 的 用 户 信息 。 如 果 输 入 了 不 存在 的 用 户 名 ， 单 击 “ 提 交 ” 按 钮 时 ， 则 会 转 到 
showquestion .php 页 面 ， 该 页 面 显 示 出 用 户 不 存在 的 错误 信息 ， 如 图 4-86 所 示 。 


ET TT 
结 生 0 | 国 we /1T 00 L/w /erentin pe 


~ ~ 
用 户 注册 资料 修改 











图 4-86 输入 的 用 户 不 存在 
ES 如 果 输 入 一 个 数据 库 中 已 经 存在 的 用 户 名 ， 然 后 单 击 “ 提 交 ” 按 钮 ， 则 正 浏 


览 器 会 自动 跳 转 到 showquestion.php 页 面 ， 如 图 4-87 所 示 。 然 后 就 应 该 在 
showquestion.php 页 面 中 输入 问题 答案 ， 测 试 showquestion php 页 面 的 执行 情况 。 





4-87 ”showquestion.php 页 面 


在 这 里 ,可 以 先 输入 一 个 错误 答案 , 检查 showquestion.php 是 否 能 够 显示 问题 
答案 不 正确 时 的 错误 信息 ， 如 图 4-88 所 示 。 

如 果 在 showquestion.php 页 面 中 输入 正确 的 答案 ， 并 单 击 “ 提 交 ” 按 钮 后 ， 浏 
览 器 就 会 转 到 showpassword.php 页 面 ， 并 显示 出 该 用 户 的 密码 ， 如 图 4-89 所 示 。 


目 黄 后 ZE 





了 而 加班 灿 些 洲 内 中 并 开 














4-89 showpassword.php 页 面 


上 述 测试 结果 表明 ， 密 码 查询 系统 已 经 制作 成 功 。 

用 户 管理 系统 的 常用 功能 都 已 经 设计 并 测试 成 功 ， 读 者 如 果 需 要 将 其 应 用 到 其 他 的 网 
站 上 ， 只 需要 修改 一 些 相 关 的 文字 说 明 及 背景 效果 ， 就 可 以 完成 用 户 管理 系统 的 制作 ， 在 
注册 的 字段 采集 时 ， 也 可 以 根据 网 站 的 需求 进一步 增加 数据 表 字 段 的 值 。 
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模块 五 


留言 往 管 理 系统 实例 的 设计 


网 站 留言 簿 管理 系统 的 功能 主要 是 实现 网 站 的 访问 者 与 网 站 管 
理 者 之 间 的 交互 。 访问 者 可 以 提出 任何 意见 和 发 出 相关 信息 ,管理 者 
可 以 在 后 台 及 时 回复 。 因此， 要 想 开发 PHP 动态 网 站 ， 对 留言 簿 管 
理 系统 的 学 习 也 是 不 可 少 的 。 

本 单元 就 使 用 PHP 开发 一 个 可 以 进行 留言 并 进行 回复 的 留言 簿 
管理 系统 ， 开 发 的 技术 主要 涉及 数据 库 留 言 信息 的 插入 、 回 复 和 修改 
信息 的 更 新 等 ， 在 设计 回复 时 间 时 ， 还 会 涉及 到 一 些 关 于 PHP 时 间 
函数 的 设置 问题 。 


。 本 模块 的 任务 重点 。 








留言 簿 管理 系统 的 整体 规划 
留言 簿 数据 库 的 建立 方法 
留言 簿 管理 系统 常用 功能 的 设计 
后 台 管理 系统 的 设计 
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E 国 1 贸 言 筹 管 理 系统 的 规划 








留言 筹 管理 系统 的 主要 功能 是 在 首页 上 显示 留言 ， 管 理 者 能 对 留言 进行 回复 、 修 改 和 
删除 ， 因 此 ， 一 个 完整 的 留言 簿 管理 系统 分 为 访问 者 留言 模块 和 管理 者 登录 模块 两 部 分 。 


1.1 页 面 规划 设计 
在 本 地 建立 站 点 文件 夹 gbook， 要 制作 的 留言 簿 系统 文件 及 文件 夹 如 图 5-1 所 示 。 


入 C:\Apache\htdocs\gbook 


文件 下) 编辑 于) 查看 WW 收 巷 ) 工具 帮助 00) 
RE . 日 让 中 扫 过 马 广 天 回 - 


地 址 四 ) | 回 c:\Apache\htdocs\ebook 


文件 和 文件 卖 任务 入 


加 8 娃 一 个 训 文件 天 
个 人文 作业 让 到 


局 共享 此 文件 天 


加 anin login php 加 | book php 
国 delbook php 加 | inde ph 
国 ] 让 

.四 


5-1 规划 站 点 文件 





本 系统 共有 6 个 页 面 ， 各 页 面 的 功能 与 对 应 的 文件 名 称 如 表 5-1 所 示 。 


表 5-1 系统 页 面 说 明 

















页 面 名 称 功 能 
index.php 显示 留言 内 容 和 管理 者 回复 内 容 
book.php 提供 用 户 发 表 留言 的 页 面 
admin login.php 管理 者 登录 留言 簿 系统 的 入 口 页 面 
admin.php 管理 者 对 留言 的 内 容 进行 管理 的 页 面 
reply.php 管理 者 对 一 留言 内 容 进行 回复 的 页 面 
delbook.php 管理 者 对 一 些 非 法 留言 进行 删除 的 页 面 


1.2 ”系统 页 面 设计 


在 网 页 美 了 
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[方面 ， 主 要 设计 了 首页 和 次 级 页 面 ， 采 用 的 是 标准 的 左右 布局 结构 ， 留 言 


页 面 的 效果 如 图 5-2 所 示 。 


中 - 国 国 入 | 记 搜 雪 支 收 VW 天 如 | 和合- 总 团 - 回 贡 文 站 ”大 
地 址 四) | 撞 http://127.0.0.1/ebook/index. php ~ 第 入 关键 词 挫 索 口 图 





你 的 位 置 -一 在 线 留言 现在 时 间 是 : 2014-08-17 


补 员 可 理 姑 些 济 内 吕 串 田山 居 需 


罗 留言 敌 
加 果 你 有 什么 问题 须要 咨询 的 话 ,请 单 击 留言 给 我 留言 ,我 们 会 第 一 时 间 给 你 答复 
记录 1 到 0 总共 0) 
了 D 号 留言 主题 : 
留言 内 容 : 来自 的 朋友 在 留言 内 容 : 


管理 回复 : 对 不 起 ， 暂 无 回复 ? 








5-2 ”留言 簿 管理 系统 的 首页 








轿 2| 系统 数据 库 的 设计 


制作 留言 短 管 理 系统 时 ， 首 先 要 设计 一 个 存储 访问 者 的 留言 内 容 、 管 理 员 对 留言 信息 
的 回复 及 管理 账号 、 密 码 的 数据 库 文件 gbook， 以 方便 管理 和 使 用 。 


2.1 数据 库 设 计 


本 数据 库 主 要 包括 “留言 信息 意见 表 ” 和 “管理 信息 表 ” 两 个 数据 表 ，“ 留 言 信息 意 
见 表 ” 命 名 为 gbook，“ 管 理 信息 表 ” 命 名 为 admin。 

操作 步 又 如 下 。 

在 phpMyAdmin 中 建立 数据 库 gbook， 单 击 硕 数 据 库 命令 打开 本 地 “数据 库 ” 
管理 页 面 ， 在 “新 建 数 据 库 ” 文 本 框 中 输入 数据 库 的 名 称 gbook， 单 击 后 面 的 数据 
库 类 型 下 拉 列 表 框 , 在 弹出 的 下 拉 菜 单 中 选择 utf8_general_ci 选项 , 单 击 [@ 坚 按钮， 
返回 “常规 设置 ”页 面 ， 在 数据 库 列表 中 就 已 经 建立 了 gbook 数据 库 ， 如 图 5-3 
所 示 。 

国 于 ZY 单 击 左边 的 gbook 数据 库 ， 将 其 连接 上 ， 打 开 “ 新 建 数据 表 ” 页 面 ， 分 别 输 
入 数据 表 名 “gbook” 和 “admin”( 即 创建 两 个 数据 表 )。 输 入 字段 名 并 设置 数据 
类 型 等 相关 内 容 ， 如 图 5-4 所 示 。gbook 表 的 字段 结构 如 表 5-2 所 示 。 
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phpMyAdmin ~ Eichee 
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5-3 ”建立 数据 库 


ET / ghonk | phpgyhdain 3.3.7 - 于 creznfy Tnrerner pmplorer 
文件 刀 ” 志 绑 加 查看 尼 ， 收 项 b)。 工具 C) 帮助 及 
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区 >x 民 > 区 >x 区 > 
局 部 局 晤 刁 雪 局 图 
日 避 目 避 司 引 目 日 
国 辐 同 刁 国 弹 国电 





二 详细 








图 5-4 创建 数据 表 gbook 





表 5-2 留言 信息 意见 表 gbook 


字段 名 称 数据 类 型 必 填 字段 





D integer 是 (自动 编号 ) 





并 


Subject Varchar 





并 


content text 























模 

块 

续 表 五 

字段 名 称 必 填 字段 

Teply 昌 
date 

Tedate 

王 也 

passid 倒 

的 

更 

计 





及 设置 数据 域 位 的 相关 数据 ， 如 图 5-5 所 示 。 
表 5-3 管理 信息 数据 表 admin 


文件 四 ”编辑 吕 ”查看 WD 收藏) 工具 0) 帮助 QD) 
地 址 | 手 http://127.0.0 1/phpllyhdnin/ index. php?db=ebookht oan=6965bScefeb4fd15fab0Sc2586d31e58 





四 localhost > 大 gbook ， 加 admin 
_ 国 浏览。 四 结构 “各 saL 户 搜索 3 新 入 别 叶 出 ” 闻 叶 入 多 操作 [ 嘲 清 空 “出 制 除 
钙 _MySQL 返回 的 查询 结果 为 空 ( 即 等 行 )。 (查询 花费 0.0006 秒 ) 








加 



































口 概要 [ 编 线 ] [ 拥 释 SQL ][ 蚀 建 PHP 代码 ][ 别 新 ] 





字段 类 型 ”整理 属性 空 默认 额外 
[= int(11) 否 无 图 
口 usemame intl50) 吾 无 国 
口 password int(50) 否 无 国 
全 先 /全 不 选 关 p 硕 国庆 XX 国 回 回国 





+ 详细， 





图 5-5 创建 的 admin 数据 表 
数据 库 创 建 完毕 以 后 ， 对 于 本 系统 而 言 ， 下 一 步 是 如 何 取得 访问 者 的 卫 地 址 。 


2.2 ”定义 系统 站 点 


在 Dreamweaver CS5.5 中 创建 一 个 “留言 德 管理 系统 ”网 站 站 点 gbook， 由 于 这 是 PHP 
数据 库 网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 5-4 所 示 。 
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动态 网 站 设计 袜 用 教 答 
表 5-4 站 点 设置 的 基本 参数 
站 点 名 称 ook 
本 机 构 目 录 C:\Apache\htdocs\gbook 
测试 服务 器 C:\Apache\htdocs\ 
网 站 测试 地 址 http://127.0.0.1/gbook/ 
MySQL 服务 器 地 址 Ci\apache\MySQL-5.0.90\data\gbook 
管理 账号 /密码 root/admin 
数据 库 名 称 book 





创建 gbook 站 点 的 具体 操作 步骤 如 下 。 
ED 首先 在 C:\Apache\htdocs 路 径 下 建立 gbook 文件 夹 (如 图 5-6 所 示 )， 本 章 建立 
的 所 有 网 页 文件 都 将 放 在 该 文件 夹 下 。 


篇 C:\Apache\htdocs 
文件 中) 编辑 到 ) 查看 
(7 和 


地 址 | 加 c: Wpsche\htdoes 


文件 和 文件 夹 任务 OO 


国 重 向 名 这 个 文件 天 
族 移 这个 文 件 天 

四 各 x 个 文件 天 

全 这 1 文 人 天机 到 
也 共 训 此 文件 严 


回 以 电子 邮件 形式 发 送 
语文 件 买 内 的 妆 
册 辽 这 个 文件 亚 


谎 万 大 来 总 文件 天 





收藏 工具 吕 D 帮助 0 
回 - 


全 名 称 
mserverseripts 2014-8-14 10:31 
2014-8-16 19:54 
2014-8-12 11:53 
2014-8-12 11:56 
2014-6-21 6:50 
2010-9-22 2:52 
2014-8-12 11:58 
2014-8-12 11:56 
2014-6-21 6:28 
2010-9-22 17:16 
2014-8-12 11:59 


局 "mb 
EE 
re 

辐 phptykAdein 
:shop 
tet 
Em 

加 inaex php 


国 cest php 1 芭 PE 文件 


图 5-6 建立 站 点 文件 夹 gbook 
ED 运行 Dreamweaver CS5.5， 从 菜单 栏 中 选择 “站 点 ”一 “管理 站 点 ”命令 ， 打 


开 “ 管 理 站 点 ”对 话 框 ， 


gbook 
member 
Php 
web 


如 图 5-7 所 示 。 








图 5-7 
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“管理 站 点 ”对 话 框 


对 话 框 的 左边 是 站 点 列表 框 , 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 [ 国 建 四， ] 
按钮 ， 打 开 “ 站 点 设置 对 象 ”对 话 框 ， 进 行 如 图 5-8 所 示 的 参数 设置 。 


站 点 设置 对 象 gbook 


amweaver 站 点 是 网 站 中 使 用 的 所 有 文件 和 资源 的 集合 。 
Et 可 在 其 中 存 人 
， 以 及 可 在 其 中 将 相同 文件 发 布 到 Web 上 的 服务 器 上 的 远程 文 
您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 , 
站 点 名 称 : [gbook 


本 地 站 点 文件 买 : [C: Wpache htdocs gbook\ 




















玫 吕 可 于 类 些 济 峙 中 避 串 上 曲山 忆 需 
































图 5-8 建立 gbook 站 点 
EEC 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 由， 打开 “ 基 
本 ”选项 卡 ， 进 行 如 图 5-9 所 示 的 参数 设置 。 


站 点 设置 对 象 gbook 
设置 来 自 








服务 器 名 称 : 
连接 方法 : L 性 作 知 Wb 六 发 








服务 器 文件 夹 [C: Apache htdocs 
Web URL: [http://127.0.0.Y/ 县 Ji 测 式 | 







































































图 5-9 设置 “基本 ”选项 卡 
国 了 BY 设置 后 ， 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 选 中 “ 维 
护 同步 信息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 框 中 选择 PHP MySQL 选项 ， 表 
示 是 使 用 PHP 开发 的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 5-10 所 示 。 
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站 点 设置 对 象 gbook 








[至 一 | 时 末 自 





可 维护 同步 信息 
口 保存 时 自动 格 文件 上 传 到 服务 器 
口 自用 文件 取出 功能 
回 打开 文件 之 前 取出 [测试 | 
取出 名称 : | 


恬 进 苦 瑚 Web 帮 发 








电子 邮件 地 址 : [| 








测试 服务 器 



























































图 5-10 设置 “高 级 ”选项 卡 
EST 单 击 于 保本 按钮， 返回 “服务 器 ”设置 界面 ， 选 中 “测试 ” 复 选 框 ， 如 
图 5-11 所 示 。 
站 点 设置 对 象 gbook 


您 将 在 此 位 置 选择 承载 Web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 
Internet 服务 提供 商 (ISP) 或 Web 管理 员 , 


兽 闻 Dreamweaver 地 点 上 工作 ， 全 无 凋 完 成 革 共 赫 。 如 办 要 进攻 到 Web 六 发 
使 过 eR 个 二 避 民 务 闪 信 可 





名 称 | 地址 | 连接 | 远程 测试 | 
gbook C/Apache/htdocs 本 地 /网络 四 MI 












































图 5-11 设置 “服务 器 ”参数 





单 击 瑟 一 保 奉 “| 按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CS5.5 中 就 
已 经 拥有 刚才 所 设置 的 gbook 网 站 了 。 单 击 [或 名 按钮， 关闭 “管理 站 点 ”对 
话 框 ， 这 样 ， 就 完成 了 Dreamweaver CSS5.5 测试 留言 簿 管理 系统 网 页 的 网 站 环境 
设置 。 
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2.3 数据库 连 接 


完成 了 站 点 的 定义 后 ， 接 下 来 就 是 用 户 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 与 数据 库 
的 连接 设置 如 下 。 
将 设计 的 本 模块 文件 复制 到 站 点 文件 夹 下 ， 打 开 indexphp， 如 图 5-12 所 示 。 


DW 将 四 棋 D 查理 轨 插 和 四 骨 妆 介 外 区 加 身 $ 回 站 上 5 加 入 DD 可 册 人 D | | 章 坦 "局 加 攻 滞 








补 员 可 于 类 些 济 内 员 避 串 旧 ”山居 需 






A RAI 
网 | 外 1 世 马 | 国 | 郊 - | 回 廿 - 
[ee >] 





| Wm LN + | 本 和 RE EO, © tra: BRET 
[TO 








生计 记过 有 各， 
近 加 引 ff) 报 几 并 娩 六 录入。 


.| 
Bae EU 
“| 人 GI SH 






































国 二 Fw [| sw | WW mh WFR | 元。 可 

二 一 | CT | 四 
号 出 史 轿 FacCC job 虽 一 一 EE 
四 [a EE 








5-12 ”打开 网 站 的 首页 


ED 从 菜单 栏 中 选择 “窗口 ”一 “数据 库 ” 命 令 ， 打 开 “ 数 据 库 ”面板 。 在 该 面板 
上 单 击 [到 按钮， 在 弹出 的 下 拉 菜 单 中 选择 “MySQL 连接 ”选项 ， 如 图 5-13 所 示 。 


动态 数据 : 
Y 1， 为 该 文件 创建 站 点 。 
Y “2.， 选择 一 种 文档 类 型 。 
3. 设置 站 点 的 负 试 服务 器 。 
4 单 击 上 面 的 + 按钮 创建 连接 。 


图 5-13 选择 “MySQL 连接 ” 


ES 在 “MySQL 连接 ”对 话 框 中 ， 输 入 “连接 名 称 ” 为 “gbook”、“MySQL 服 
务 器 ”名 为 “localhost”、“ 用 户 名 ”为 “root”、“ 和 密码 ”为 “admin”。 选 择 所 
要 建立 连接 的 数据 库 名 称 ， 可 以 单 击 [选取 | 按钮 浏览 MySQL 服务 器 上 的 所 有 数 
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据 库 ， 选 择 刚 建立 的 范例 数据 库 gbook， 具 体 的 设置 内 容 如 图 5-14 所 示 。 


了 7SQL 连接 





连接 名 称 : ,gbook 
WiyS9L 服务 器 : |localhost 
用 户 名 : root 














密码 : [ree 
数据 库 : [gbook 

















5-14 设置 MySQL 连接 参数 


EC 单 击 [_ 五 | 按 钮 测试 与 MySQL 数据 库 的 连接 是 否 正确 , 如 果 正 确 , 则 弹出 
提示 消息 ， 这 表示 数据 库 连接 设置 成 功 了 ， 如 图 5-15 所 示 。 


和 y5QL 连接 区 








5-15 ”提示 设置 成 功 


ED 单 击 [_ 克 ”| 按钮 ， 则 返回 编辑 页 面 ， 在“ 数据库 ”面板 中 显示 绑 定 过 来 的 
数据 库 ， 如 图 5-16 所 示 。 






效 据 库 | 绑 定 | 服务 器 行为 | | 
十 一 文档 类 型 : PIF c 
日 国 sbook 
蝇 - 团 ”脚本 编制 
圈 adnin 






器 ”gbook 
Be <ontent (text 必需 的 ) 
一 旺 8 date (date 必需 的 ) 
ID Gint 11 必需 的 ) 
IP (varchar 50 必需 的 ) 
passid (varchar 20 必需 的 ) 


VI 
了 
一 
Be redate (date 必需 的 ) 
fw 
fa 






reply (text 必需 的 ) 
subject (varchar 50 必需 的 ) 








田 





图 
存 过 程 


出 当 一 


加 
天 


田 


图 5-16 绑 定 的 数据 库 
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3| 留言 秒 的 首页 和 留言 页 面 


留言 簿 管理 系统 分 前 台 和 后 台 两 部 分 ， 这 里 首先 制作 前 台 部 分 的 动态 网 页 ， 主 要 有 留 
言 敌 首页 index.php 和 留言 页 面 book.php。 


3.1 留言 首页 


在 留言 首页 index.php 中 ， 单 击 “ 留 言 ” 超 链接 时 ， 将 会 打开 留言 页 面 book.php， 访 问 
者 可 以 在 上 面 自由 发 表意 见 ， 但 管理 人 员 可 以 对 恶意 留言 进行 删除 、 修 改 等 。 

其 制作 的 详细 步骤 如 下 (为 叙述 准确 ， 所 涉及 的 表格 均 以 英语 字母 顺序 命名 )。 

ED 创建 index.php 文档 。 首 先 ， 设 置 页 面 属性 ， 包 括 默 认 字 体 、 大 小 12、 背 景色 
#CCCCCC、 上 下 左右 边 距 为 0。 然 后， 在 页 面 中 插入 表格 A(3x2， 宽 750， 居中 对 
齐 ， 其 他 0)， 合 并 第 一 行 单元 格 ， 插 入 图 片 images/logo.jpg， 合 并 第 三 行 单元 格 ， 
设置 高 50， 背 景色 为 #55C2EB， 水 平 居 中 对 齐 ， 输 入 文字 “Copyright@2011-2012 
hbculture.com Inc.All rights reserved. 环 博文 化 版 权 所 有 ”。 第 二 行列 宽 分 别 为 195 
和 555。 

ER) 在 表格 A 的 第 二 行 第 一 列 单元 格 内 插入 表格 B(1x1， 宽 100%， 其 他 0); 在 表 
格 B 中 插入 表格 C(1x1， 宽 90%， 其 他 0); 在 表格 C 中 插入 表格 D(5x1， 宽 98%， 
其 他 0)， 设 置 各 行 高 分 别 是 133、36、155、25 和 83。 

四 E> 对 表格 D 的 第 一 行 单元 格 设置 背景 (background=“images/index.02.gif*)， 插 入 
表单 form2， 在 表单 内 插入 表格 E(5x1， 宽 100%， 其 他 0)， 各 行 高 为 38、25、20、 
25 和 12。 在 第 二 行 输入 文字 “用 户 名 : ”， 其 后 插入 文本 域 (名 为 usemame， 单 
行 , 字符 宽度 15); 在 第 三 行 输入 文字 “ 密 码 : ”, 其 后 插入 文本 域 (名 为 password， 
单行 ， 字符 宽度 15); 在 第 四 行 插入 两 个 按钮 ， 分 别 是 “提交 ”(Submit)、“ 重 置 ” 
(Submit2);， 在 第 五 行 输入 文字 “注册 新 用 户 找 回 密码 ”。 

EC 在 表格 D 的 第 二 行 插入 图 片 images/index_04.gif; 第 三 行 插入 图 片 images/ 
lxwm.jpg; 第 四 行 插入 文字 “洽谈 合作 ”， 第 五 行 插入 图 片 images/memeber.gif。 

Eneg 在 表格 A 的 第 二 行 第 二 列 单元 格 插入 表格 E(5x1， 宽 100%， 其 他 0)， 各 行 高 
分 别 是 30、40、25、20。 

在 表格 E 第 一 行 单元 格 输入 文字 “你 的 位 置 -在线 留言 ”和 “现在 时 间 是 : ”。 

在 表格 下 第 二 行 单元 格 插入 图 片 images/14384-m.jpg， 输入 文字 “留言 簿 ”( 黑 
体 ， 大 小 16， 红 色 )。 

EC 在 表格 E 的 第 三 行 输入 文字 “如 果 你 有 什么 问题 需要 咨询 的 话 ， 请 单 击 留言 





补 冠 加 理 类 点 洲 峙 呈 剖 串 旧 ”山居 项 
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给 我 留言 ， 我 们 会 第 一 时 间 给 你 答复 。”。 

在 表格 EE 的 第 四 行 输入 文字 “记录 到 (总 共 )”， 回 车 换行 ， 插 入 表格 F(1x4， 
宽 40%， 边 框 0， 右 对 齐 )， 在 单元 格 中 分 别 输入 “第 一 页 ”、“ 前 一 页 ”、“ 下 一 
页 ”~ “最 后 一 页 ”。 

在 表格 EE 的 第 五 行 插入 表单 form1， 表 单 内 插入 表格 G(4x3， 宽 90%， 边 框 0， 
居中 对 齐 )， 列 宽 为 8%、18% 和 76%， 行 高 为 20、20、30 和 25。 

EC 在 表格 E 的 第 一 行 的 第 一 个 单元 格 中 输入 文字 “ID 号 ”， 在 第 二 个 单元 格 中 
输入 文字 “留言 主题 : ”。 

EC 在 表格 EE 的 第 二 行 第 二 个 单元 格 中 输入 文字 “留言 内 容 : ”， 将 第 三 个 单元 格 
拆 分 成 两 行 ， 在 第 一 行 单元 格 中 输入 文字 “来 自 的 朋友 在 留言 内 容 : ”。 

EC 在 表格 EE 的 第 三 行 第 二 个 单元 格 中 输入 文字 “管理 回复 : ”， 第 三 个 单元 格 输 
入 文字 “管理 员 在 回复 内 容 : ”。 

ES 了 9》 在 表格 的 第 一 行 单元 格 的 文字 “现在 时 间 是 : ”的 后 面 加 上 如 下 PHP 代码 (加 
入 后 会 出 现形 标记 ): 


<?php 
date default timezone set('Asia/Shanghai'); 
echo date ("Y-m-d h:i:s"); 

2> 


得 到 系统 当前 时 间 , 在 表格 EE 的 第 三 行文 字 “ 留 言 ” 上 作 一 个 超 链 接 ， 链 接 到 book .php 





(二 bork pm YY 名 己 )， 效 果 如 图 5-17 所 示 。 
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责 _ 宝 耐克 而 在 癌 衣 夯 


| Rm | SW A MD 志 避 避 。 志 要 [ES 
人 @ 上 而 夯 可 区 内 有 公 林 出 肌 条 加 捷 夫 到 的 动机 人 之 文件 。 伍 去 | 于 这 全 站 




















PHP ies 

















SE le ry A NO TT rt S10v 29 /19 Weicsts re-3) | 











图 5-17 首页 的 效果 


ESD) 创建 记录 集 Rs, 在 “ 绑 定 ”面板 上 单 击 [到 按钮 ， 从 弹出 的 下 拉 菜单 中 选择 “ 记 
录 集 (查询 )” 选 项 ， 在 弹出 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 : 
e 在 “名 称 ” 文 本 框 中 输入 “Rs” 作 为 该 “记录 集 ”的 名 称 。 
e@ ”在 “连接 ”下 拉 列 表 框 中 选择 连接 对 象 为 gbook。 
e@ 在 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 gbook。 
@ ”在 “ 列 ” 单 选 按钮 组 中 ， 选 中 “全 部 ” 单 选 按钮 。 
完成 后 的 设置 如 图 5-18 所 示 。 


闻 克 加 弄 装具 洲 肝 哎 逆 趾 蛆 ” 岂 红 项 

















5-18 “记录 集 ” 对 话 框 
ED) 单 击 [到] 按钮 ， 进 行 高 级 模式 绑 定 ， 在 SQL 文本 框 中 输入 如 下 代码 : 


SELECT * 
FROM gbook // 从 数据 库 中 选择 gbook 表 
WHERE passid=0 // 选 择 的 条 件 为 passid 为 0 
当 此 SQL 语句 从 数据 表 gbook 中 查询 出 所 有 的 passid 字段 值 为 0 的 记录 时 ， 表 示 此 留 
言 已 经 通过 管理 员 的 审核 ， 如 图 5-19 所 示 。 





























图 5-19 输入 SQL 语句 
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单 击 [ 确定 ”| 按钮 ， 完 成 记录 集 的 绑 定然 后 将 此 字段 插入 index.php 网 页 的 
适当 位 置 ， 如 图 5-20 所 示 。 








5-20 ” 绑 定 字段 


ES 在 “管理 回复 ”单元 格 中 ， 根 据 数据 表 中 的 回复 字段 reply 是 否 为 空 ， 来 判断 
管理 者 是 否 访问 过 。 如 果 该 字段 为 空 ， 则 显示 “对 不 起 ， 暂 无 回复 !” 字 样 信息 ， 
如 果 该 字段 不 为 空 ， 就 表明 管理 员 对 此 留言 进行 了 回复 ， 同 时 还 会 显示 回复 的 时 
间 和 内 容 。 

ED 在 设计 视图 中 ， 选 中 “管理 回复 ”单元 格 ， 找 到 “对 不 起 ， 暂 无 回复 !” 字 样 ， 
并 加 入 以 下 代码 (如 图 5-21 所 示 ): 


<?php 
if ($row Rs['reply']= empty($row Rs['reply'])) { 
echo "对 不 起 ， 暂 无 回复 ! "; 
} // 如 果 reply 字段 为 空 则 显示 


else { 











图 5-21 加 入 代码 
由 于 index.php 页 面 显示 的 是 数据 库 中 的 部 分 记录 ， 而 目前 的 设 定 只 会 显示 数 
据 库 的 第 一 笔 数 据 ， 因 此 ， 需 要 加 入 “服务 器 行为 ”中 “重复 区 域 ”的 设 定 ， 选 
择 index.php 页 面 中 需要 重复 显示 的 内 容 ， 如 图 5-22 所 示 。 
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测 
落 理 员 在 很 sredate} 回复 内 容 : 
Reeply). 





图 5-22 选择 要 重复 显示 的 内 容 
单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”面板 中 的 “添加 服务 器 行为 ” 


按钮 [二 ， 在 弹出 的 下 拉 菜单 中 选择 “重复 区 域 ”选项 ， 在 打开 的 “重复 区 域 ”对 
话 框 中 设 定 显示 的 数据 选项 ， 如 图 5-23 所 示 。 


补品 可 覃 类 些 济 队员 避 串 旧 出世 需 




















5-23 “重复 区 域 ”对 话 框 


EPZ) 单 击 [_ 厂 | 掖 钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 的 区 域 左上 角 出 现 了 一 
个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设 定 了 。 

EPE) 将 鼠标 指针 移 至 要 加 入 “记录 集 导航 条 ”的 位 置 ， 在 “插入 ” 栏 的 “数据 ” 
类 别 中 单 击 “ 记 录 集 分 页 ”按钮 医 ]， 在 弹出 的 对 话 框 中 选取 要 导航 的 记录 集 以 及 
导航 的 显示 方式 ， 然 后 单 击 [确定] 按钮 回 到 编辑 页 面 ， 此 时 ， 页 面 就 会 出 现 该 
记录 集 的 导航 条 ， 效 果 如 图 5-24 所 示 。 


DW 文件 四 捕手 四 查看 揪 入 修改 呈 格式 四 命 人 站 点 四 全 DO 和 DW | 图 ”六 ”| 医 h "|] [ESEE 司 























数据 
加 | 双 马 马 忆 | 芭 | 名 -| 国 覆 - | 可] 说 -| 印 区 - 多 区 | 多 -| 加 窗口 风格 
| | 人 ET 

















图 5-24 加 入 “记录 集 导航 条 ” 
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EEEZ》 将 鼠标 指针 移 至 页 面 表格 的 右上 角 ， 并 在 “插入 ”工具 栏 的 “数据 ”类 别 中 
单 击 “ 显 示 记 录 计 数 ” 按 钮 量 j， 在 弹出 的 对 话 框 中 选取 要 显示 状态 的 记录 集 ， 再 
单 击 [_ 确定 ”按钮 ， 回 到 编辑 页 面 ， 此 时 ， 页 面 就 会 出 现 该 记录 集 的 导航 状态 ， 
如 图 5-25 所 示 。 


a 

ERE rary I or TE 

SR SN NN 
On 

















5-25 ”加 入 “记录 集 导航 状态 ” 


留言 的 首页 index.php 至 此 已 经 设计 完成 了 。 打开 正 浏览 器 , 在 地 址 栏 中 输入 
“http://127.0.0.1/gbook/index.php”， 对 首页 进行 测试 ， 由 于 现在 数据 库 中 没有 数 
据 ， 所 以 测试 效果 如 图 5-26 所 示 。 


ET 
CT FE TET 





二 时 作用 条 二 要 入 沁 内 活 ， 由 阳 人 闫 全 训 ， 和 位 党 一 时 间 站 休 共 各。 
记录 1 到 9B 可 
De YE 
再 窑 :。 直肠 灵 在 名言: 





E:T, SAR 








图 5-26 留言 簿 管理 系统 主页 的 测试 效果 


3.2 留言 页 面 


本 节 将 要 制作 访问 者 的 在 线 留 言 功 能 ， 通 过 “服务 器 行为 ”面板 中 的 “插入 记录 ” 功 
能 ， 实 现 将 访问 者 填写 的 内 容 插入 到 数据 表 gbook 中 。 
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制作 步骤 如 下 。 

ED 从 菜单 栏 中 选择 “文件 ”一 “新 建 ” 命 令 ， 打 开 “ 新 建文 档 ” 对 话 框 ， 创 建 
新 页 面 ， 从 菜单 栏 中 选择 “文件 ”一 “另存 为 ”命令 ， 将 新 建文 件 在 根 目录 下 保 
存 为 book.php。 

供 访问 者 留言 的 静态 页 面 book.php 与 主页 面 index.php 大 体 一 致 , 页 面 效 果 如 
图 5-27 所 示 。 
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5-27 ”book.php 页 面 的 效果 


EEJey 在 留言 簿 表单 内 部 ， 分 别 执行 三 次 “插入 记录 ”一 “表单 ”一 “隐藏 区 域 ” 
命令 ,插入 三 个 隐藏 区 域 ， 选 中 其 中 一 个 隐藏 区 域 ， 将 其 命名 为 “IP”: 


<input name="IP" type="hidden" id="IP" 
value="<?php echo $_SERVER['REMOTE ADDR'];?>" />// 自 动 取得 用 户 的 IP 地 址 


并 在 属性 面板 中 对 其 赋值 ， 如 图 5-28 所 示 。 


IE | 
| 


IP 值 人 0 | 人 ?php echo $_SERVER[ REMOTE_ADDR| 多 























图 5-28 设 定 IP 值 
EU 再 选择 另外 一 个 隐藏 区 域 ， 命 名 为 “date”， 并 在 “ 值 ”文本 框 中 输入 获取 系 
统 时 间 的 代码 (如 图 5-29 所 示 ): 


<input name="date" type="hidden" id="date" 
Value="<?php date default timezone set('Asia/shanghai'); 
echo date ("Y-m-d h:i:s");?>"> 
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属性 


NI 隐藏 区 域 
date 和 值 @ | 人 ?phpdate_default_timezrone. _set( | 多 





























图 5-29 设置 时 间 


EC 同样 ， 设 置 第 3 个 隐藏 区 域 的 字段 名 称 为 “passid”，“ 值 ”为 0， 表 示 任 何 
留言 者 在 留言 时 生成 的 passid 值 为 0, 管理 者 可 以 根据 这 个 值 进 行 判断 , 方便 后 面 
的 管理 ， 如 图 5-30 所 示 。 








隐 蕊 区 域 
N | 值 ) 0 


[passid 











5-30 设置 passid 的 值 为 0 


ECG 单 击 “应 用 程序 ”一 “服务 器 行为 ”面板 中 的 [到 按钮 ， 从 弹出 的 下 拉 菜 单 中 
选择 “插入 记录 ”选项 ， 在 打开 的 “插入 记录 ”对 话 框 中 设置 参数 ， 在 “ 列 ” 列 
表 框 中 会 自动 配置 相应 的 字段 插入 ， 其 中 没有 配置 的 值 是 供 管理 者 进行 插入 使 用 
的 。 完 成 后 的 设置 如 图 5-31 所 示 。 


插入 记录 

















"FORM. subject” "文本 
从 “FOBN. content” 获 取 值 作为 “文本 ” 


获取 值 。 
从 FORM date” 获 职 值 作为 “日 期 ' 


a 信 作 四 ,文本 
Passid 获取 值 作为 “文本 


























图 5-31 “插入 记录 ”对 话 框 
单 击 [确定 ”| 按钮 ， 回 到 网 页 设计 编辑 页 面 ， 这 样 就 完成 了 页 面 book.php 插 
入 一 条 记录 的 设置 。 
有 些 访 问 者 进入 留言 页 面 book.php 后 ， 不 填 任何 数据 就 直接 把 表单 送出 ， 这 
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样 ， 数 据 库 中 就 会 生成 一 笔 空白 数据 。 为 了 阻止 这 种 现象 发 生 ， 须 加 入 “检查 表 
单 ” 的 行为 。 具体 操作 是 在 book php 的 标签 检测 区 中 ， 单 击 <form1> 标 签 ,然后 单 
击 “ 行 为 ”面板 中 的 [区 按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “检查 表单 ”选项 。 

ECGD》 “检查 表单 ”行为 会 根据 表单 的 内 容 来 设 定 检查 方式 ， 留 言 者 一 定 要 填 入 标 
题 和 内 容 ， 因 此 将 subject、content 这 两 个 字段 的 值 设置 为 “必需 的 ”， 这 样 就 可 
完成 “检查 表单 ”的 行为 设 定 了 ， 具 体 设置 如 图 5-32 所 示 。 


玫 员 可 于 类 些 济 内 串 串 旧 ”出 忆 需 























可 接受 ， @ 任何 东西 。 。 〇 数字 
〇 电子 邮件 地 址 〇 数字 从 [ | 到 | | 





图 5-32 选择 并 设置 必 填 字段 
ED 单 击 [_ 确 | 按钮 ， 完 成 留言 页 面 的 设计 ， 如 图 5-33 所 示 。 


| 十， 蕊 加 硬 纪 








Mh EBMEW| | 日 | 
ROOUmv | BM = EE 



































图 5-33 完成 的 页 面 








上 二 4| 系统 的 后 台 管理 功能 
留言 簿 后 台 管理 系统 可 以 使 系统 管理 员 通 过 admin login php 进行 登录 管理 ， 管 理 者 全 
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录 页 面 的 设计 效果 如 图 5-34 所 示 。 


向 c- pacheihtdocs\gbockiadain_liogin php 


RET ebook php 











[Cbody> Cform#forml> 








SQ ox 568 x 131v 6 K/1 WD Unicode (UTF-8) 








5-34 系统 员 管 理 入 口 页 面 
4.1 管理 者 登录 入 口 页 面 


管理 页 面 是 不 允许 一 般 网 站 访问 者 进入 的 ， 必 须 受到 访问 权限 约束 。 页 面 设 计 的 具体 
操作 步骤 如 下 。 
ED 打开 制作 的 静态 页 面 adtmin_ login php。 单 击 “ 应 用 程序 ”面板 中 的 “服务 器 
行为 ”标签 上 的 [ 国 按 钮 ， 在 弹出 的 下 拉 菜单 中 选择 “用 户 身份 验证 /登录 用 户 ” 选 
项 , 弹出 “登录 用 户 ” 对 话 框 , 在 对 话 框 中 设置 “如 果 登 录 失 败 , 转 到 ”为 index.php， 
“如 果 登 录 成 功 ， 转 到 ”为 admin php， 如 图 5-35 所 示 。 





























基于 以 下 项 限制 访问 : @ 用 户 名 和 密码 


用 户 各、 密码 和 访问 昭 别 
诡 取 级 别 自 : 





图 5-35 “登录 用 户 ” 对 话 框 


ER29 从 菜单 栏 中 选择 “窗口 ”一 “行为 ”命令 ， 打 开 “ 行 为 面板 ”， 单 击 该 面板 
中 的 | 者 j 按 钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “检查 表单 ”选项 ， 弹 出 “检查 表单 ”对 
话 框 ， 设 置 usemame 和 password 文本 域 的 值 都 为 “必需 的 ”、 可 接受 为 “任何 东 
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西 ”， 如 图 5-36 所 示 。 





PF “username” (R) 














: 思 必需 的 





可 接受 : @O 任何 东西 〇 数字 
〇 ”电子 邮件 地 址 〇 数字 从 


闻 克 丑 型 先 瞪 洲 肝 哎 泌 趾 昌 ” 岂 夺 匡 





图 5-36 “检查 表单 ”对 话 框 
ED) 单 击 [_ 一 | 按 钮 ， 回 到 编辑 页 面 ， 管 理 者 登录 入 口 页 面 admin login php 的 
设计 制作 都 已 经 完成 。 
4.2 ”管理 页 面 


后 台 管 理 页 面 admin.php 是 管理 者 由 登录 页 面 验证 成 功 后 所 跳 转 到 的 页 面 。 这 个 页 面 提 
供 删 除 和 编辑 留言 的 功能 ， 效 果 如 图 5-37 所 示 。 


:Woechevhtdocr\evook Vedatn shor 


Dx 

CRY chook php 了 
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加 此 页 面 可 能 具有 仅 可 由 服务 器 搜索 型 ll 下 访 相 关 文 件 。 搜 索 | 首选 佐 洲 


代 诡 卫 公司 资讯 。 论坛 


PHP astramas EE 


100% O69) 
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< 
[hody? Ctable) Ctr> td) 《table Cr> ta ableY Lr Hd [RJD QR 100x ~ 755 x 252v 58 /9 各 Unicode (WTF-6) 














图 5-37 “管理 页 面 ”的 设计 效果 


操作 步骤 如 下 。 

ED 打开 admin.php 页 面 ， 此 页 面 设计 比较 简单 ， 在 这 里 不 做 说 明 ， 单 击 “ 绑 定 ” 
面板 上 的 [二 | 按钮， 从 弹出 的 下 拉 菜 单 中 选择 “记录 集 ( 查 询 )” 选 项 ， 打 开 “ 记 录 
集 ” 对 话 框 ， 在 该 对 话 框 中 进行 如 下 设置 : 
®@ 在 “名 称 ” 文 本 框 中 输入 “Rs” 作 为 该 记录 和 集 的 名 称 。 

e ”从 “连接 ”下 拉 列 表 框 中 ， 选 择 数据 源 连接 对 象 gbook。 
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@ 从“ 表格” 下拉 列表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 gbook。 
e@ 在“ 列 ” 栏 中 选中 “全 部 ” 单 选 按钮 。 
@ 设置 “排序 ”方法 为 以 “ID” 一 “降序 ”。 
单 击 [_ 确定 “| 按钮 完成 设 定 ， 如 图 5-38 所 示 。 





















































5-38 “记录 集 ” 对 话 框 
ER 绑 定 记录 集 后 ， 将 记录 集 字段 插入 到 admin.php 网 页 的 适当 位 置 ， 如 图 5-39 








所 示 。 
[名 ce MApache\htdocs\gbook\adnin. php ue 
ED Doo tte eg Eu 
全 此 页 面 可 能 具有 人 色 可 由 服务 器 搜索 到 | 的 动态 相关 文件 。 搜 索 | 首选 才 数 © 


PHP 留言 管理 系统 


首页 1 新 闻 ? 1 ”信息 服 





加 果 符 合 此 条 件 则 显示 








注 是 沟 容 下 营 理 
ID} :Rs.subject} ARs.content} {RsIP} 狗 除 回复 二 
< > 
Cbody> [NR] Q 100% ~ 755x258v 64 Kk/10 秒 Unicode (UTF-8) 

















图 5-39 绑 定 的 字段 


admin .php 页 面 的 功能 是 显示 数据 库 中 的 部 分 记录 , 而 目前 的 设 定 则 只 会 显示 数 
据 库 的 第 一 笔 数 据 , 需要 加 入 “服务 器 行为 ”中 的 “重复 区 域 ”命令 , 选择 admin .asp 
页 面 中 需要 重复 显示 的 区 域 ， 如 图 5-40 所 示 。 
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35% CI 





让 生 汪 28% (tsgjv + 2% CTU + 一 135seflogv | 














图 5-40 ”选择 要 重复 的 内 容 


单 击 “ 服 务 器 行为 ”面板 上 的 [二 按钮 ， 从 弹出 的 下 拉 菜单 中 选择 “重复 区 域 ” 
选项 , 在 打开 的 “重复 区 域 ” 对 话 框 中 设置 一 页 显示 的 数据 选项 , 例如 10 条 记录 ， 
如 图 5-41 所 示 。 


区 | 


1 


. 请 
2 已 本 





〇 ”所 有 记录 





5-41 “重复 区 域 ” 对 话 框 
ED 单 击 [_ 厂 | 按钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 的 区 域 左上 角 出 现 了 
一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 
选取 记录 集 有 记录 时 要 显示 的 记录 表格 ， 如 图 5-42 所 示 。 


同 ci\apache\htdocs\ sbock\adain. php -Ox 


RT gbook php 





~ PHP wmss 























< | > 
Ctable> Ctr> Cd> Te bidder E HOT table> [了 局 oo% v755 x 330v 64 K / 10 秒 Unicode (WTF-8) 








图 5-42 选择 有 记录 时 要 显示 的 表格 
单 击 “ 服 务 器 行为 ”面板 中 的 [tj] 按钮 ， 在 弹出 的 下 拉 列 表 中 选择 “显示 区 域 ” 
一 “如 果 记 录 集 不 为 空 则 显示 区 域 ”选项 ， 在 打开 的 “如 果 记 录 集 不 为 空 则 显示 
区 域 ” 对 话 框 中 , 选择 “记录 集 ”下 拉 列 表 框 中 的 Rs 选项 , 再 单 击 [确定 ”| 按钮 ， 


玫 吕 可 于 类 些 浏 附 中 避 串 田山 居 项 
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@ [©] PHP+MySQL 


回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 显示 的 区 域 左 上 角 出 现 了 一 个 “如 果 符 合 此 
条 件 则 显示 ”的 灰色 卷 标 ， 这 表示 已 经 完成 设 定 了 ， 如 图 5-43 所 示 。 


国 c: wpachevhtdoesvgbocx\adatin phoy 





PHP sims 


EI 新 闻 翅 

















如 | | 


| 
Ore) 








图 5-43 ”完成 的 设置 
输入 记录 集 没 有 记录 时 要 显示 的 内 容 “ 目 前 没有 任何 留言 ”， 如 图 5-44 所 示 。 




















图 5-44 选择 没有 记录 时 要 显示 的 页 面 内 容 
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单 击 “服务 器 行为 ”面板 中 的 [ 邮 按 钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “显示 区 域 ” 
一 “如 果 记 录 集 为 空 则 显示 区 域 ”， 在 打开 的 “如 果 记 录 集 不 为 空 则 显示 区 域 ” 
对 话 框 中 ， 选 择 “记录 集 ” 下 拉 列 表 框 中 的 Rs 选项 ， 如 图 5-45 所 示 。 再 单 击 
[确定 ”| 按钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 的 要 显示 的 区 域 左上 角 出 现 了 一 
个 “如 果 符 合 此 条 件 则 显示 ”的 灰色 卷 标 ， 这 表示 已 经 完成 设 定 了 。 


训 果 记录 和 集 为 空 则 显示 





闻 克 丑 弄 装具 洲 肝 哎 刻 趾 蛆 ” 岂 左 项 








5-45 ”设置 “如 果 记 录 集 为 空 则 显示 ”的 区 域 


ED 将 光标 移 至 要 加 入 记录 集 导航 条 的 位 置 ， 在 “插入 ”工具 栏 的 “应 用 程序 ” 
类 别 中 ， 单 击 “ 记 录 集 分 页 ”按钮 大 4， 在 弹出 的 对 话 框 中 选取 要 导航 的 记录 集 以 
及 导航 的 显示 方式 ， 然 后 单 击 [确定 ”按钮 回 到 编辑 页 面 ， 会 发 现 页 面 出 现 该 记 
录 集 的 导航 条 ， 如 图 5-46 所 示 。 


国 c:WApache\hsdocsvgbookvadain sho 加 











REY chook php 


供应 求购 资讯 论坛 


PHP wees 

















Cepyright@2011L2012 kbculnure 





刁 | 
[Cbody> Ctable> Ctr> Ctay Rtable7 (RQ lox ~ 807 x 43v 64 K/ 10 秒 Unicode QTF-6) 














图 5-46 加 入 记录 和 集 导 航 条 


ED 单 击 页 面 中 的 “回复 ”文字 ， 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 
击 “ 浏 览 文件 ” 回 按 钮 ， 在 弹出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 
reply.php， 设 置 如 图 5-47 所 示 。 
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选择 文件 名 自 : @) 文件 系统 
口 数 据 源 





坦 找 范围 O:[ 忆 ao 同 @ 生 已 回 - 











;reply ph ][ 




















文件 名 四 

文件 类 型 | 所 有 文件 fc 本 司 [Cm ] 
WL: [eeply. phprID= cphp echo $row Rs ID ]; ?| [ 雪 数 

HB 于: [六 省 司 sinpip 

在 站 点 定义 中 更 2 对 认 的 让 拉扯 对 于 


5-47 ”选择 链接 文件 


EDP) 单 击 LLS 履 .按钮 ， 设 置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 。 将 参数 名 
称 命名 为 ID， 值 的 设置 如 图 5-48 所 示 。 





白 

















5-48 “参数 ”对 话 框 


EECE) 单 击 [本 一 按钮 ， 回 到 编辑 页 面 , 选取 编辑 页 面 中 的 “删除 ”二 字 , 在 “ 属 
性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 览 文件 ”图 标 ， 在 弹出 的 对 话 框 中 
选择 用 来 显示 详细 记录 信息 的 页 面 delbook php， 并 设置 传递 ID 参数 ， 如 图 5-49 


所 示 。 
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园 择 文件 名 自 ; 外 文件 系统 
〇 六 闫 源 


查找 范围 四 -| 局 ebook 
局 _mseveseripts [a) sinin_login php 
be 








delbook php?ID= CTphy scho Srov_Rs[ ID J 


相对 于 : 文档 din php 
在 站 点 定义 中 更 改 默认 的 链接 相对 于 


图 5-49 设置 “删除 ”的 链接 


EC) 单 击 [_ 胡 | 按钮 ， 回 到 编辑 页 面 ， 单 击 “ 应 用 程序 ”面板 中 的 “服务 器 行 
为 ”标签 上 的 [本 按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “用 户 身份 验证 ”一 “限制 对 页 
面 的 访问 ”选项 ， 在 打开 的 “限制 对 页 的 访问 ”对 话 框 中 设置 “如 果 访 问 被 拒绝 ， 
则 转 到 ”为 “admin login php” 页 面 ， 如 图 5-50 所 示 。 


限制 对 页 的 访问 


基于 以 下 内 容 进行 限制: 中 ” 症 户 如 和 过 友 
〇 有” 用户 名 、 客 码 和 沪 问 级 别 

















jets | [EX 


如 果 访 问 被 拒绝 ， 则 转 到 ;adnin_login php EE 





闻 克 加 型 竺 瞪 洲 肝 哎 族 趾 昌 ” 岂 红 项 











5-50 “限制 对 页 的 访问 ”对 话 杠 
ED 单 击 [_ 胡 按钮 ， 就 完成 了 后 台 管理 页 面 admin.php 的 制作 。 


4.3 回复 留言 页 面 


回复 留言 页 面 的 功能 ， 主 要 是 通过 reply.php 页 面 对 用 户 留言 进行 回复 ， 实 现 的 方法 是 
将 数据 库 的 相应 字段 绑 定 到 页 面 中 ， 管 理 员 在 “回复 内 容 ” 中 填写 内 容 ， 单 击 “ 回 复 ” 按 
钮 ， 可 以 将 回复 内 容 更 新 到 gbook 数据 表 中 ， 页 面 效 果 如 图 5-51 所 示 。 


和 cr Uaioets mtdoes beni\opiy mm -Ox 








ED + 公司 咨讯 。 论坛 


统 请 畏 入 悠 夺 兴 起 的 产品 





















































图 5-51 回复 留言 页 面 
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reply.php 页 面 动态 功能 的 制作 步骤 如 下 。 

创建 reply.php 页 面 ， 并 单 击 “ 绑 定 ” 面板 上 的 [四 按钮， 从 弹出 的 下 拉 菜 单 中 ， 
选择 “记录 集 ( 查 询 )” 选 项 ， 在 打开 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 

在 “名 称 ” 文 本 框 中 输入 “Rs” 作 为 该 记录 集 的 名 称 。 

从 “连接 ”下 拉 列 表 框 中 ， 选 择 数据 源 连 接 对 象 gsbook。 

从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 sbook。 

在 “ 列 ” 栏 中 选中 “全 部 ” 单 选 按钮 。 

设置 “筛选 ”的 方法 为 “ID” 一 “=” 一 “URL 参数 ”一 “ID”。 

单 击 [ 确 时 按钮 完成 设 定 ， 如 图 5-52 所 示 。 














图 5-52 ”设置 绑 定 的 “记录 集 ” 
ED 绑 定 记录 集 后 , 再 将 绑 定 字段 插入 到 reply.php 网 页 的 适当 位 置 ,如 图 5-53 所 示 。 


国 c: Apache\htdocsgpookiraplr sho* = 


LAY ebook php 


























{Rs. content} 





























; 客户 电话 : 010-12345678 9 
BD Ctable) Ctr> Cdy 《form .. > Ctable? Ctr> tay Iabel Rteztarea [NI A ox ~ 807 x 382v 129 K /19 秒 Unicode (UTF-8) 














图 5-53 在 页 面 中 插入 绑 定 字段 
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在 本 页 面 中 添加 两 个 隐藏 区 域 ， 一 个 为 redate， 用 来 设 定 回复 时 间 ， 赋 值 等 于 
“<?php date_default timezone set(‘Asia/Shanghai’): echo date(“Y-m-d h:i:s”): ?>”， 
另外 一 个 是 passid， 用 来 决定 是 否 通过 审核 的 一 个 权限 ,赋值 为 0 时 ,就 自动 通过 
审核 ， 如 图 5-54 所 示 。 
| 


回 二 二 


[redate 值 D | cphpdate_default_timerone_setd 到 




















玫 吕 可 于 姑 些 浏 内 串 串 旧 出世 需 











加 汪汪 值 轨 0 多 




















图 5-54 设置 “隐藏 区 域 ”两 个 字段 的 属性 
EEC 单 击 “ 服 务 器 行为 ”面板 上 的 “添加 服务 器 行为 ”按钮 是 ， 从 弹出 的 菜单 中 ， 
选择 “更 新 记录 ”选项 ， 如 图 5-55 所 示 ， 用 于 根据 留言 内 容 对 数据 库 中 的 数据 进 
行 更 新 。 


获取 更 多 服务 器 行为 .… . 














图 5-55 选择 “更 新 记录 ” 


在 弹出 的 “更 新 记录 ”对 话 框 中 ， 按 图 5-56 所 示 进 行 更 新 记录 设置 。 
ED 单 击 [_ 厂 | 校 钮 回 到 编辑 页 面 ， 这 样 就 完成 了 回复 留言 页 面 的 设置 。 
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“ FORM. x Ey 
RM. IP” 作为 “文本” 
“passid 从 hn et 各 取信 作为 “文本 








图 5-56 设置 “更 新 记录 ”对 话 框 


4.4 删除 留言 页 面 


删除 留言 页 面 对 应 delbook.php 文件 ,其 功能 是 将 表单 中 的 记录 从 相应 的 数据 表 中 删除 ， 
页 面 的 设计 效果 如 图 5-57 所 示 ， 详 细 说 明 步 又 如 下 。 


国 ceaaiaaeaaeanaiakae 


口 x 

全 和 下 hook phy 入 
© 

A 












人 @ 此 页 面 可 能 具有 仅 可 由 服务 器 搜索 到 的 动态 相关 文件 搜索 | 首 达 考 数 


BB 求购 公司 资讯 论坛 
PHP 留言 管理 系统 


请 输入 您 感 兴趣 的 产品 车 搜索 
首页 | 新 闻 1 








































[bodyy <taEl1a>Ktry 《tay <tabLe》>Xtr> Cd) Cfora#fornl> [WIG To0x -jamrz450v 127 K/ 19 和 Wnicode (WTF-8) 





图 5-57 ”删除 留言 页 面 的 效果 
打开 delbook.php 页 面 , 单 击 “ 绑 定 ” 面 板 上 的 [二 | 按钮 , 在 弹出 的 下 拉 菜 单 中 ， 
选择 “记录 集 (查询 )” 选 项 ， 在 弹出 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 : 
@ 在“ 名称” 文本 框 中 输入 “Rs” 作 为 该 记录 集 的 名 称 。 
@ ”从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 象 gbook。 
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@ ”从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 gbook。 

@ 在 “ 列 ” 栏 中 选中 “全 部 ” 单 选 按钮 。 

e@ 设置 “筛选 ”的 方法 为 “ID” 一 “=” 一 “URL 参数 ”一 “ID”。 
单 击 [ 珊 是] 按钮 完成 设 定 ， 如 图 5-58 所 示 。 




















闻 克 丑 型 竺 瞪 洲 肝 哎 亡 趾 昌 ” 岂 夺 匡 
































图 5-58 设置 绑 定 的 “记录 集 ” 


ES 绑 定 记录 集 后 , 再 将 记录 集 的 字段 插入 到 delbook.php 网 页 的 各 说 明文 字 后 面 ， 
如 图 5-59 所 示 。 





图 c: WApachevhtdocs\gbookvdeibook php 





CER ebook php 


1 
国 忆 四 












{Rs. date} 















































| 
: 
[| 1 
{Rs. IP} ! 
{Rs. subject} ! 
{Rs. content} 司 | 
| | 

| | 国 
到 | 
{Rs. reply} 回 
| 
| 
El ! 
删除 ] [ 重 办 ] | 
Chody> Ctable> Ctr> <td> <table> Ctr> Cdy Cform#fornl > [RS lo0% v807 x 4r2v 128 K / 19 秒 Unicode (UTF-8) 

图 5-59 ”字段 的 绑 定 
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在 delbook.php 的 页 面 上 ， 单 击 “ 服 务 器 行为 ”面板 上 的 [而 | 按钮 ， 从 弹出 的 下 
拉 菜单 中 选择 “删除 记录 ”命令 ， 如 图 5-60 所 示 ， 用 于 对 数据 表 中 的 数据 进行 删 
除 操作 。 


服务 器 行为 

十 一 文档 类 型 : PIT 

| 。 记录 集 
重复 区 域 
记录 集 分 页 上 
显示 区 域 
显示 记录 计数 
动态 文本 
插入 记录 
更 新 记录 

[Si 好 
动态 表单 元 素 上 
用 户 身份 验证 » 
XSLT 转换 
编辑 服务 器 行为 .. 
新 建 服务 器 行为 . 

后 获取 更 多 服务 器 行为 . 一 


5-60 ”选择 “删除 记录 ”命令 
ECG 在 打开 的 “删除 记录 ”对 话 框 中 进行 设置 ， 如 图 5-61 所 示 。 














首先 检查 是 否 已 定义 变量 :| 主 津 值 
连接 : | gbook 
表格 : | abook 














主键 列 : | 
主妇 值 ; |URL 参数 
删除 后 , 转 到 : |adnin. php 





图 5-61 “删除 记录 ”对 话 框 
ED 单 击 [_ 友 | 按钮 回 到 编辑 页 面 后 ， 就 完成 了 删除 留言 页 面 的 设置 。 
5| 留言 簿 系统 的 测试 


留言 秒 系 统 部 分 用 到 了 手写 代码 ， 特 别 是 留言 的 日 期 和 回复 日 期 ， 其 中 还 涉及 到 了 留 
言 者 的 卫 采集 ， 为 了 检查 开发 系统 的 正确 性 ， 需 要 测试 留言 功能 的 执行 情况 。 
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5.1 前 台 留 言 测试 


具体 的 前 台 测试 步骤 如 下 。 
EID 打开 正 浏览 器 ， 在 地 址 栏 中 输入 “http://127.0.0.1/gbook/index.php”， 打 开 
index.php 文件 ， 如 图 5-62 所 示 。 


辐 留 言 首页 - Microsoft Internet Explorer 
文件 @) 加 经 到 ) 查看 0 收 芯 人 工具 CD) 帮助 00 
增 直 加 | 四 http://127 0 0 1/ebock/index php 





求购 公司 资讯 论坛 


PHPwssazku Cars ， 民 


你 的 位 置 一 在 线 留言 


用 户 各 : 罗 留 言 敌 


和 加 果 你 什么 问题 要 闪 询 的 话 ,请 单 击 名 计 申 我 留言 ,我 们 全 弟 一 时 间 给 他 答复 。 
jl 记录 1 到 0(8 共 站 
广角 新 用 户 后记 码 时 人 让 主 是 : 


全 言 内 容 : 来 自 的 朋友 在 留言 内 容 


芝 理 占 复 : 对不起， 暂 无 回复 ! 
NAN 
\ 


We 








图 5-62 首页 的 效果 
ED 单 击 “ 留 言 ” 超 链接 ， 就 可 以 进入 留言 页 面 bookphp， 如 图 5-63 所 示 。 


罚 留 言 - Wicrosoft Internet Explorer 
文件 中 编辑 下 查看 WD 收藏) 工具 CI) 帮助 0 
地 址 名 | 掩 http://127.0.0.1/ebook/book php 





[3 求购 公司。 资讯。 论坛 


PHP，swwmzuk [Crsrs | 


用 PP 名 : | 


引 的 沪 问 ,请 生 下 你 全 人 的 意见 





注册 新 用 户 技 回 密码 md "最 多 为 50 个 字符 
se 车 言 内 容 


Es snre 








图 5-63 留言 页 面 的 效果 
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国 了 BY 开始 检测 留言 簿 功能 ， 在 “留言 主题 ” 栏 中 填写 “测试 留言 主题 ”在 “留言 
内 容 ” 栏 中 填写 “测试 留言 的 内 容 ”。 填 写 完 后 ， 单 击 “ 提 交 ” 按 钮 ， 此 时 会 弹 
出 index.php 页 面 ， 可 以 看 到 多 了 一 个 刚 填写 的 数据 ， 如 图 5-64 所 示 。 


~ Microsoft Internet Explorer 
文件 EF) 编辑 时) 查看 YW) 收藏 A) 工具 DD) 帮助 中 
地 址 四 ) | 斩 http;/1/127.0.0. 1/gbook/index. php? 








供应 求购 。 公司 资讯 。 论坛 


了 HP se 和 


你 的 位 置 一 在 线 留言 


用 户 名 : 加 留言 筹 
| 加 果 你 有 什么 同 是 关 要 次 刘 的 话 ， 语音 击 留言 结 我 久 言 ,我 们 会 划一 时 间 给 你 答复 。 
加 |E] 记录 1 到 1( 共 D 
AE 村 本 池 了 人 D 号 留言 主题 : 测试 留言 的 主题 
本 来 自 1270.0.4 的 朋友 在 留言 内 容 : 
9 外 内 宇 :。。 测 入 言 的 内 容 
对 不 起 ， 暂 无 回复 ! 








5-64 ”向 数据 表 中 添加 的 数据 


5.2 后台 管理 测试 


后 台 管 理 在 留言 秒 管 理 系统 中 起 着 很 重要 的 作用 ， 制 作 完 成 后 也 要 进行 测试 ， 操 作 步 
又 如 下 。 
EEC) 打 一 开 浏 览 器 ， 在 地 址 栏 中 输入 “http://127.0.0.1/gbook/admin loginphp”， 
打开 admin login.php 文件 ， 如 图 5-65 所 示 。 在 网 页 的 表单 对 象 的 文本 框 及 密码 框 
中 ， 输 入 用 户 名 及 密码 ， 输 入 完毕 后 ， 单 击 “ 登 录 ” 按 钮 。 


@f 扫 -日 - 国 国 的 记 抽 雪 去 收 V& 天 如 四 - 马 转 
地 址 @) | 秋 http:/1127.0.0. 1/abook/adnin login php 


留言 板 管理 系统 后 台 登 录 
用 户 ，[ 











密码 ， 


图 四 








图 5-65 后 台 管 理 入 口 
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如 果 上 一 步 中 填写 的 登录 信息 是 错误 的 ， 则 浏览 器 会 转 到 index.php 主页 面 ; 
如 果 输 入 的 用 户 名 和 密码 都 正确 ， 则 进入 admin php 页 面 ， 如 图 5-66 所 示 。 


加 后 台 管理 - 了 icrosoft Internet Ezplorer 
OOF- 日 - 国 国 扒 | 记 雪 二 办 收 BR 全 全 -名 国 - 日 芭 
地 主 站) 阐 http://127.0.0.1/gbook/ sdnin_ php 








GE 下 购 公司 资讯 论坛 


PHP mw sss EE 


首页 | 新 地 动 克 信息 服务 | 信息 知识 | 信息 产业 


闻 克 加 型 竺 瞪 洲 肝 思 族 趾 蛆 ” 岂 夺 项 


内 容 
测试 留言 的 内 容 








5-66 ”留言 管理 页 面 


单 击 “删除 ” 超 链 接 ， 进 入 删除 页 面 delbook.php， 并 自动 将 该 留言 信息 删除 。 
删除 留言 后 ， 返 回 留言 管理 页 面 adtmin.php 。 

ER 在 留言 管理 页 面 单 击 “ 回 复 ” 超 链接 ， 则 进入 回复 页 面 replyphp， 如 图 5-67 
所 示 。 


OBE- 日 - 国 国 从 | 记过 友 必 天 名 全 -及 加 -加 总 
地 圭 四 | 秋 http:/7127.0.0.1/gbookyreply php?ID=0 





公司 
请 输入 您 和 兴起 的 产品 大 搜 家 
首页 1 新 闻 动 恋 于 法 | 和 
会 出 登录 您 的 位 置 一 一 回复 留 言 。。 现在 的 时 间 是 : 2014.08.17100623 
] 到 mwar: 
密码 ; 次 要 辐 复 久 言 的 ID 呈 是 0 号 : 
Ei: [2014-08-17 
留言 者 P: 1127001 
名言 和 题 : | 测试 的 主题 
测试 的 留言 内 容 
入 内 容 : 


注册 新 用 户 找 回 密码 


回复 内 容 : 


客户 电话 : 010-12345678 
传真 ; 010-12345678 








图 5-67 回复 页 面 
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当 填 写 回复 内 容 “ 回 复 测试 ”， 并 单 击 “ 回 复 ” 按 钮 后 ， 将 成 功 回复 留言 。 
本 实例 制作 的 留言 簿 管理 系统 在 功能 上 相对 还 是 比较 简单 的 ， 读 者 如 果 需 要 进行 深入 
开发 实践 ， 可 以 在 此 基础 上 做 一 些 变 化 ， 使 所 制作 的 留言 簿 能 够 更 加 入 性 化 一 些 。 
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在 线 投票 管理 系统 实例 的 设计 


网 站 的 投票 管理 系统 设置 好 投票 主题 后 ， 网 站 的 会 员 积极 参与 ， 
可 以 起 到 活跃 会 员 、 增 加 浏览 量 的 作用 。 一 个 投票 管理 系统 可 分 为 3 
个 主要 功能 模块 : 投票 功能 、 投 票 处 理 功能 以 及 显示 投票 结果 功能 。 

投票 管理 系统 首先 给 出 投票 选 题 ( 即 供 投票 者 选择 的 表单 对 象 )， 
当 投票 者 单 击 选择 投票 按钮 后 ， 投 票 处 理 功能 激活 ， 对 服务 器 传送 过 
来 的 数据 做 出 相应 的 处 理 ， 先 判断 用 户 选 择 的 是 哪 一 项 ， 累 计 相应 项 
的 字段 值 ， 然 后 对 数据 库 进行 更 新 ， 最 后 将 投票 的 结果 显示 出 来 。 


。 本 模块 的 任务 重点 。 








投票 管理 系统 站 点 的 设计 
投票 管理 系统 数据 库 的 规划 
计算 投票 的 方法 

防止 刷新 的 设置 
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外 1| 执行 投票 管理 系统 规划 

在 线 投票 管理 系统 在 设计 开发 之 前 ， 对 将 要 开发 的 功能 进行 一 下 整体 的 规划 。 本 实例 
可 以 分 为 3 个 部 分 的 页 面 内 容 ， 一 是 计算 投票 页 面 ， 二 是 显示 投票 结果 页 面 ， 三 是 用 来 提 
供 选 择 的 页 面 。 
1.1 页 面 规划 设计 


根据 介绍 的 投票 管理 系统 的 页 面 设计 规划 ， 在 本 地 站 点 上 建立 站 点 文件 夹 vote， 将 要 
制作 的 投票 管理 系统 的 文件 夹 和 文件 如 图 6-1 所 示 。 








篇 C:\apache\htdocs 

文件 @) 编辑 EE) 查看 WW) 收藏 由 工具 G) 帮助 0D 
恨 - 曲 -和 舍 记 搜索 已 文人 天 国 - 

地 址 呈 | 加 c:\apsche\htdocs 


文件 和 文件 夹 任务 


国 生命 名 这 个 文件 天 
敬称 5 这 个 文件 严 
站 复审 这 个 文件 到 


全 村 这 人 文人 发 到 
检 共 这 此 文件 天 

电子 邮 1 
将 
XK 出 辽 这 个 文件 





图 6-1 创建 站 点 文件 夹 
本 实例 制作 的 投票 系统 共有 4 个 页 面 ， 页 面 的 功能 和 文件 名 称 如 表 6-1 所 示 。 
表 6-1 在 线 投票 系统 的 网 页 构成 














页 面 名 称 功 能 
vote.php 在 线 投票 管理 系统 的 首页 
voteadd.php 统计 投票 的 功能 
Voteok.php 显示 投票 结果 
sorry.ph] 投票 失败 页 面 


1.2 ”系统 页 面 设计 
投票 管理 系统 的 页 面 共 4 个 ， 包 括 开始 投票 页 面 、 计 算 投 票 页 面 、 显 示 投 票 结果 页 面 
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本 


以 及 投票 失败 页 面 。 计 算 投 票 页 面 voteadd php 的 实现 方法 是 : 接收 vote php 所 传递 过 来 的 
参数 ， 然 后 执行 累加 的 功能 。 为 了 保证 投票 的 公正 性 ， 本 系统 根据 IP 地 址 的 唯一 性 设置 了 
防止 页 面 刷新 的 功能 。 开 始 投 票 页 面 和 显示 投票 结果 页 面 的 设计 如 图 6-2 和 6-3 所 示 。 








对 员 加 下 娄 些 洲 脂 节 少 落 卜 二 


请 你 投票 ?9 Y 本 投票 只 可 投票 一 次 

















编 得 是) 查看 WD 收 套 罗 。 工具 GD) 村 各 0 























图 6-3 ”投票 结果 的 显示 页 面 








团 :| 系统 数据 库 的 设计 


本 实例 主要 掌握 投票 管理 系统 数据 库 的 连接 方法 ， 投 票 管理 系统 的 数据 库 主 要 用 来 存 
储 投票 选项 和 投票 次 数 。 
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2.1 数据 库 的 设计 


投票 管理 系统 需要 一 个 用 来 存储 投票 选项 和 投票 次 数 的 数据 表 vote 和 用 于 存储 用 户 IP 
地 址 的 数据 表 jp。 
制作 的 步骤 如 下 。 





管理 页 面 ,在 “新 建 数据 库 ” 文 本 框 中 输入 数据 库 的 名 称 “vote”， 如 图 6-4 所 示 。 
单 击 打开 后 面 的 数据 库 类 型 下 拉 菜 单 ， 选 择 IE 了 选项， 单 击 世 到 按钮 ， 返 回 
“常规 设置 ”页 面 ， 在 数据 库 列 表 中 就 建立 了 vote 数据 库 。 


鱼 127- 0.0-1:8080 / localhost | phpllyAdain 3.3.7 - Wicrosoft Internet Explorer 
文件 中 妨 得 ED) 查看 WD 收藏 和 ) 工具 CD) 帮助 0 
堵 直 四) | 四 http://127.0.0.1:8080/phplyAdaiayindex php?ab=vetelateken=b042Ss81eccSTcl1cgeTTel4Tdal8T11 


phpMyAdmin “加 Iocalhost 








多 数据 库 好 SQL 章 状 态 国 变量 国字 符 集 轩 引 擎 ”多 权限 复制 
回回 加 加 区 蝶 进 程 总 导出 可 导 入 究 同 步 



































。 information_schema 
(17) 操作 MySQL 


» member (1) 全 修改 密码 胃 服 务 器 :localhostvia 
as 和 基本 50.90 


“pice MySQL localhost pe 
敬 新 建 数据 库 加 ”用 户 : root@localhost 
vote TFT ~ 图 MySQL 字符 集 : UTF-8 
Unicode (utf8) 


本 
图 MySQL 连接 校对 : | ut8_general ci 网 站 服务 器 


界面 » Apache/2.0.63 (Win32) 
PHP/5.2.14 


多 Language 四 -| 中 文 - Chinese simplified ， MySQL 客户 端 版 本 : 5.0.90 疝 
国 Intenet 








图 6-4 创建 vote 数据 库 


EDPp 单 击 左边 的 vote 数据 库 ， 将 其 连接 上 ， 出 现 “新 建 数据 表 ” 页 面 ， 分 别 输入 
数据 表 名 “ip” 和 “vote”( 即 创建 两 个 数据 表 )。ip 数据 表 的 字段 结构 如 表 6-2 所 
示 ， 用 于 限制 重复 投票 、 输 入 数据 域名 以 及 设置 数据 类 型 的 相关 数据 。 


表 6-2 ip 数据 表 
数据 类 型 字段 大 小 必 填 字段 





int 








varchar 


此 时 的 “新 建 数据 表 ” 页 面 如 图 6-5 所 示 。 
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所 


127.0.0.1:8080 / localhost / vote | phpEyAdain 3.3.7 一 Microsoft Internet Explorer 
文件 如 编辑 世 ) 查看 WD 收藏 和 ) 工具 CD) 帮助 0 
地 址 加) | 四 http://127.0.0.1:8080/phplyAdnin/index. php?db=votel&token=b0425s81ecc9Tcl1c9eTTe147da16711 








加 localhost ， 时 vote 
畸 结 构 “加 SQL 万 搜索 “。 昌 查询 总 导出 本 导入 


加 副 除 
表 “ 









































口 
口 vote 


2 个 表 utf8_general ci 2.0 0 
HB 字 


对 员 加 下 娄 些 洲 脂 节 少 落 此 二 


人 全 选 /全 不 选 选中 项 ， 因 





打印 预览 蜗 效 据 字典 





广 误 在 数据 库 vote 中 新 建 一 个 数据 表 一 
< 


入 Internet 





图 6-5 创建 数据 表 
设计 vote 数据 表 用 于 储存 投票 的 选项 和 投票 的 数量 ， 输 入 数据 域名 以 及 设置 
数据 域 位 的 相关 数据 ， 如 图 6-6 所 示 。 对 访问 者 的 留言 内 容 做 一 个 全 面 的 分 析 ， 设 
计 vote 表 的 字段 结构 如 表 6-3 所 示 。 

















CT 
立 伸 他 ) 蝙 可 化) 查看 八路 (和 和 动 0 
MD [My /7 127.0 0.1:-0000 /hoyhinin snd hg dh =o lol ht omer DZS sol eeedT cll coor Tol tase 


于 localhost ， @ vote » 加 vote 
加 浏览 。 辐 结构 nSQL 声 搜 索 ”有 括 入 ” 虹 导 出 ” 晰 导入 尖 操 作 






































加 

















类 型 整理 1 .证 - > 
性 


1 ID ni) 否 

口 item varchar(50) ut8_general OG 否 

口 vote int(20) 否 天 
企 _ 全 和 达 /全 不 过 间 中 大 国 湖 X 图 回 加 加 


恒 打 印 预 帘 肠 规 划 表 结构 田 
于 未 刘 由 个 宝 邮 全 干 责 纤 号 二 页 开 4 二 之 后 [DSI 











[CT 


6-6 vote 数据 表 


表 6-3 ”投票 数据 表 vote 








意义 必 填 字段 
主题 编号 是 
投票 主题 是 
投票 数量 是 
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EU 为 了 方便 后 面 系统 开发 的 需要 ， 事 先 在 vote 数据 表 里 加 入 4 条 投票 的 数据 ， 
单 击 “ 浏 览 ” 选 项 卡 ， 在 数据 表 中 手工 加 入 名 为 “选项 一 ”至 “选项 四 ”的 4 个 
选择 模式 ， 如 图 6-7 所 示 。 





ET EEC 
二 址 四 EE 





加 localhost， 局 vote 四 vote 
同济 览 “ 鹤 结构 ， 避 SQL 万 搜索 订 黄 入 瞳 导 出 ”前 导入 其 操 作 硬 请 空 “加 日 除 
-3 人 4 总 计 , 坦 词 花 要 00007 种 ) 












































口 慨 概 [ 泌 生 ][ 和 解 入 SOL11 创 隆 PHP 代码 ][ 别 新 ] 





[J 行 ， 开始 行 数 ， [0 
以 [本 剖 剖 式 显 示 ， 并 且 在 1% 行 后 草 复 标 是 


7 
x 
x 
FX 
全 选 


1 全 不 选 普 P 页 六 X 图 
3 相国“ ] 行 , 开始 行 效 ， [0 
以 [至 司 神 式 显 示 ， 并 且 在 00。 行 后 重复 标 是 








查阅 结果 过 项 
[至 fe Si EH CREATE VEW 





图 6-7 输入 投票 选择 
数据 库 创建 完毕 ， 可 以 发 现 ， 在 线 投票 管理 系统 的 数据 库 相 对 比较 简单 。 


2.2 创建 投票 管理 系统 的 站 点 


在 Dreamweaver CS5.5 中 创建 一 个 投票 系统 网 站 站 点 vote, 由 于 这 是 PHP 数据 库 网 站 ， 
因此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 6-4 所 示 。 
表 6-4 在线 投票 管理 系统 站 点 的 基本 参数 














站 点 名 称 Vote 

本 机 根 目录 C:\Apache\htdocs\vote 

测试 服务 器 C:\Apache\htdocs 

网 站 测试 地 址 http://127.0.0.1/vote/ 

MySQL 服务 器 地 址 C:\Apache MySQL-5.0.90\data\vote 
管理 账号 /密码 root/admin 

数据 库 名 称 Vote 





创建 vote 站 点 的 具体 操作 步骤 如 下 。 
ESD 首先 在 C:\Apache\htdocs 路 径 下 建立 vote 文件 来， 如 图 6-8 所 示 ， 本 例 所 有 建 
立 的 网 页 文件 都 将 放 在 该 文件 夹 下 。 
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CC:\apache\htdocs 

文件 四 编辑 四 查看 四。 收 训 和 ”工具 中 帮助 四 
@ 提 -日 -个 呈 扫 已 文 4 六 | 国 - 

地 址 WD) | c: \apache\htdoes 





文件 和 文件 夹 任务 


恩 重 命名 这 个 文件 严 
鸭 移动 这 个 文件 夹 
加 梨 制 这 个 文件 夹 
BS] 将 这 个 文件 夹 发 布 到 
el 
苹 共享 此 文件 夹 
以 电子 邮件 形式 发 送 
9 内 


XX 弄 除 这 个 文件 来 He 


6-8 ”建立 站 点 文件 夹 vote 





过 项 


半 苘 丑 弄 特 瞪 淋 山 胡 酒 光 煤 财 


7 运行 Dreamweaver CS5.5， 执 行 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 


开 “ 管 理 站 点 ”对 话 框 ， 如 图 6-9 所 示 。 




















图 6-9 “管理 站 点 ”对 话 框 


EDUS) 对 话 框 的 左边 是 站 点 列表 框 , 用 于 显示 所 有 已 经 定义 的 站 点 。 单 击 [ 攻 蛙 加- ] 按 


钮 ， 弹 出 “站 点 设置 对 象 ” 对 话 框 ， 进 行 如 图 6-10 所 示 的 参数 设置 。 


版 可 控制 奖 ， 以 及 可 在 其 中 格 相同 文生 类 布 到 Web 上 的 服务 器 上 的 远程 文 


修 可 以 在 此 处 为 Dreamweaver 站 点 和 连 捧 本 地 文件 到 和 名 称 - 
Wael 
雯 于 站 文 半天 [ceoedeWacwae， | 








rr ramweaver 区 点 是 网 站 中 使 用 的 所 有 文件 和 稀 驻 的 村 合 ，Dreamweaver 
ET 
































图 6-10 建立 vote 站 点 
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ES 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 [二 ]， 打 开 “ 基 
本 ”选项 卡 ， 进 行 如 图 6-11 所 示 的 参数 设置 。 


站 点 设置 对 得 vote 


L 





图 6-11 “基本 ”选项 卡 的 设置 

设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 选 中 “ 维 
护 同步 信息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 框 中 选择 “PHP MySQL”( 表 示 
是 使 用 PHP 开发 的 网 页 )， 其 他 的 保持 默认 值 ， 如 图 6-12 所 示 。 


站 上 





图 6-12 设置 “高 级 ”选项 卡 


ED) 单 击 [保守 “| 按钮 返回“ 服务 器 ”设置 界面 ， 选 中 “测试 ” 复 选 框 ， 如 
图 6-13 所 示 。 














JL 
您 将 在 此 位 置 选择 短 载 上 的 出 的 慨 务 吉 . 此 对 活 框 的 设置 来 自 
Internet 服务 提供 商 (ISP) 或 Web 管理 员 在 
-| 此 褒 : 票 开 涛 下 Dreamweaver 益 点 上 工作 ， 佐 五 调 过 成 此 步 坟 加 要 要 进 扣 更 Web 办 发 线 
认 而 曾 ， 估 只 商业 一 六 反 加 基 务 种 可 - 投 
票 
各 区 地 址 连接 ”运程 测 工 | ] 管 
ES Clapachefhtdocs ET 区 区 
E 
系 
统 
中 
丽 
计 
































图 6-13 设置 “服务 器 ”参数 


ED 单 击 [_ 保 村 “| 按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CS5 中 就 已 
经 拥有 了 刚才 所 设置 的 站 点 vote。 单 击 [过 成 名 按钮， 关闭 “管理 站 点 ”对 话 框 ， 
这 样 就 完成 了 Dreamweaver CS5.5 测试 在 线 投票 系统 网 页 的 网 站 环境 设置 。 


2.3 数据库 连 接 


完成 了 站 点 的 定义 后 ， 接 下 来 就 是 用 户 系统 网 站 与 数据 库 之 间 的 连接 ， 网 站 与 数据 库 
的 连接 设置 如 下 。 
将 光盘 中 设计 的 本 章 静态 文件 复制 到 站 点 文件 夹 下 ， 打 开 vote.php 投票 首页 ， 
如 图 6-14 所 示 。 
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图 6-14 打开 网 站 首页 
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TY 从 菜单 栏 中 选择 “窗口 ”一 “数据 库 ” 命 令 ， 打 开 “ 数 据 库 ”面板 。 在 “ 数 
据 库 ”面板 中 单 击 志 图 标 ， 并 在 弹出 的 下 拉 菜 单 中 选择 “MYySQL 连接 ”选项 ， 
如 图 6-15 所 示 。 





二 动态 数据 : 
Y 1， 为 该 文件 创建 站 点 。 
Y ”2.， 选择 一 种 文档 类 型 。 





图 6-15 选择 “MySQL 连接 ” 
ED 在 “MySQL 连接 ”对 话 框 中 输入 “连接 名 称 ” 为 “vote”，“MysQL 服务 器 ” 
名 为 “localhost”，“ 用 户 名 ”为 “root”， 密 码 为 “admin”。 选 择 所 要 建立 连接 
的 数据 库 名 称 ， 可 以 单 击 [选取 .按钮 浏览 MySQL 服务 器 上 的 所 有 数据 库 。 选 择 
刚 建 立 的 范例 数据 库 vote， 具 体 的 设置 内 容 如 图 6-16 所 示 。 





连接 名 称 ; vote 
sqL 服务 器 : [1ocalhost 
用 户 名 : root 

















密码 :+++ 
数据 库 : |vote 





图 6-16 设置 MySQL 连接 参数 


单 击 [_ 到 志 ”] 按 钮 测试 与 MysQL 数据 库 的 连接 是 否 正确 ， 如 果 正确 ,会 弹 
出 一 个 提示 消息 框 ， 如 图 6-17 所 示 ， 这 表示 数据 库 连接 设置 成 功 了 。 




















图 6-17 设置 成 功 


ED 单 击 [_ 厂 | 掖 钮 ， 则 返回 编辑 页 面 ， 在“ 数据库 ”面板 中 显示 绑 定 过 来 的 
数据 库 ， 如 图 6-18 所 示 。 


< 206 


=| 届 车 





图 6-18 ” 绑 定 的 数据 库 


对 而 可 于 类 些 洲 内 狙 落 些 用 








3 | 在 线 投 票 管理 系统 的 开发 


对 投票 管理 系统 来 说 ， 需 要 重点 设计 的 页 面 是 开始 投票 页 面 vote php 和 投票 结果 页 面 
voteok.php。 计 算 投票 页 面 voteadd.php 是 一 个 动态 页 面 , 没有 相应 的 静态 页 面 效 果 ， 只 有 累 
加 投票 次 数 的 功能 。 


3.1 开始 投票 页 面 的 功能 


开始 投票 页 面 vote php 主要 是 用 来 显示 投票 的 主题 和 投票 的 内 容 ， 让 用 户 进行 投票 ， 
然后 传递 到 voteadd.php 页 面 中 进行 计算 。 详 细 的 操作 步骤 如 下 。 
ED 新 建 vote .php 文档 , 设置 页 面 属性 (外 观 CSS): 背景 色 #CCCCCC、 字 大 小 12、 
上 边 距 0， 输 入 网 页 标题 “开始 投票 页 面 ”， 然 后 插入 一 个 4 行 1 列 的 表格 A， 宽 
度 600， 其 他 为 0， 对 页 面 居中 对 齐 。 
在 表格 A 的 第 一 、 二 、 四 个 单元 格 中 , 分 别 插入 图 像 vote_01.gif、 vote_02.gif、 
vote_04.gif; 选择 第 三 个 单元 格 ， 设 置 背景 色 为 性 FFFFF， 并 拆 分 为 3 列 ， 设 置 第 
1、3 列 的 单元 格 宽度 为 76、 高 度 为 271。 
在 第 二 列 单元 格 中 插入 表单 ， 并 设置 如 图 6-19 所 示 的 属性 。 在 表单 中 插入 一 
个 3x2 表格 B， 宽 度 75% 、 边 框 1、 居 中 对 齐 ， 各行 高 度 分 别 是 30、25、25， 列 
宽 14%、86% 。 合 并 表格 B 第 一 、 第 三 行 单元 格 ， 在 第 一 行 输入 文本 “你 投 的 选 
项 是 : ”， 在 第 二 行 第 一 列 单元 格 中 插入 一 个 “ 单 选 按钮 ”， 并 在 “属性 ”面板 
中 将 它 命 名 为 “ID”。 


方法 
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fornl 












































选 定 值 | cphp echo $row 初始 状态 〇 已 多 先 (C) 
Im 区 动态 .. | 加 未 渤 中 避 














图 6-19 设置 表单 及 单 选 按钮 的 属性 
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EC 在 表格 B 的 第 三 行 单元 格 中 执行 “插入 ”一 “表单 ”一 “按钮 ”命令 ， 插 入 
两 个 按钮 ， 一 个 是 用 来 提交 表单 的 按钮 ， 命 名 为 “投票 ”， 另 外 一 个 是 用 来 查看 
投票 结果 的 按钮 ， 命 名 为 “查看 ”， 如 图 6-20 所 示 。 
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6-20 投票 首页 的 效果 


ED) 单 击 “ 应 用 程序 ”面板 中 “ 绑 定 ”标签 上 的 [区 j 按 钮 ， 从 弹出 的 下 拉 菜 单 中 先 
择 “ 记 录 集 (查询 )” 选 项 ， 在 打开 的 “记录 集 ” 对 话 框 中 输入 设 定 值 ， 如 图 6-21 
































图 6-21 “记录 集 ” 对 话 框 


绑 定 记 录 集 后 ， 将 记录 集中 的 字段 item 插入 单 选 按钮 右边 的 单元 格 中 ， 如 
图 6-22 所 示 。 
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nd 时 

图 6-22 ”将 记录 集 的 字段 插入 到 vote.php 网 页 中 肥 
ED 单 击 单 选 按钮 ， 将 字段 ID 绑 定 到 单 选 按钮 上 ， 绑 定 后 ， 在 单 选 按钮 的 属性 面 
板 的 选 定 值 中 添加 了 插入 ID 字段 的 相应 代码 “<?php echo $row_Rsvote[‘ID”]; ?>”， 国 

计 


如 图 6-23 所 示 。 














在 式 : 无 ~ 


并 码 ; | <?php echo Srow_Rsvote[' ID ]; ?> 





6-23 ”插入 字段 到 单 选 按钮 


的 技巧 @ 单 击 边框 选中 表格 ， 指 向 表格 边框 时 ， 按 Ctrl 键 查看 结构 ( 行 、 列 、 单 元 格 
均 可 ); @ 选 中 表格 后 出 现行 ( 列 ) 选 择 标记 时 ， 查 看 行 ( 列 ) 结 构 ; @@ 按 住 Shift 
键 并 拖 动 ， 可 保留 其 他 行 高 (或 列 宽 ) 而 只 改变 当前 行 高 (或 列 宽 ); @ 按 住 Ctrl 
键 ， 在 表格 内 移动 鼠标 ， 可 查看 单元 格 ， 单 击 可 选择 单元 格 ; 回 在 表格 中 按 
住 Shift 键 可 以 选择 整个 表格 。 


选择 vote php 页 面 中 表单 内 表格 的 第 二 行 单元 格 ， 如 图 6-24 所 示 。 


上 Eee : 
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图 6-24 选择 记录 行 
单 击 “ 服 务 器 行为 ”面板 上 的 [二 按钮 ， 从 弹出 的 下 拉 菜单 中 选择 “重复 区 域 ” 
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选项 , 在 打开 的 “重复 区 域 ” 对 话 框 中 设 定 一 页 显示 Rsvote 记录 集中 的 所 有 记录 ， 
如 图 6-25 所 示 。 








6-25 “重复 区 域 ” 对 话 框 


EY 单 击 王 本 一 | 校 钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 的 区 域 左 上 角 出 现 了 
一 个 “重复 ”灰色 标签 ， 如 图 6-26 所 示 ( 红 色 圈 内 )， 这 表示 已 经 完成 设置 。 


i 














6-26 设置 重复 后 的 效果 


ED 在 votephp 页 面 中 ， 将 鼠标 放 在 表格 中 ， 在 “标签 选择 器 ”上 单 击 <form> 标 
签 ， 并 在 “属性 ”面板 中 设置 表单 forml 的 “动作 ”为 设置 投票 数据 增加 的 页 面 
“voteadd.php”， 设 置 “方法 ”为 “POST”， 如 图 6-27 所 示 。 





图 6-27 设置 表单 动作 


下 面 简单 介绍 一 下 PHP$_GET 变量 和 $_POST 变量 。 

$_GET 变量 : 该 变量 是 一 个 数组 ， 内 容 是 由 HTTP GET 方法 发 送 的 变量 名 称 和 值 。 

$_GET 变量 用 于 收集 来 自 method-“get "的 表单 中 的 值 。 从 带 有 GET 方法 的 表单 发 送 的 
信息 , 对 任何 人 都 是 可 见 的 (会 显示 在 浏览 器 的 地 址 栏 中 ), 并 且 对 发 送 的 信息 量 也 有 限制 (最 
多 100 个 字符 )。 
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在 使 用 $_GET 变量 时 ， 所 有 的 变量 名 和 值 都 会 显示 在 URL 中 。 所 以 ， 在 发 送 密码 或 其 
他 敏感 信息 时 ， 不 应 该 使 用 这 个 方法 。 不 过 ， 正 因为 变量 显示 在 URL 中 ， 因 此 可 以 在 收藏 
夹 中 收藏 该 页 面 ， 在 某 些 情 况 下 这 是 很 有 用 的 。 

$_POST 变量 ; 该 变量 是 一 个 数组 ， 内 容 是 由 HITP POST 方法 发 送 的 变量 名 称 和 值 。 

$_ POST 变量 用 于 收集 来 自 method-“post* 的 表单 中 的 值 。 从 带 有 POST 方法 的 表单 发 
送 的 信息 ， 对 任何 人 都 是 不 可 见 的 (不 会 显示 在 浏览 器 的 地 址 栏 中 )， 并 且 对 发 送信 息 的 量 也 
没有 限制 。 

应 该 在 任何 可 能 的 时 候 对 用 户 输入 进行 验证 。 客 户 端的 验证 速度 更 快 ， 并 且 可 以 减轻 
服务 器 的 负载 。 不 过 ， 任 何 流量 很 高 以 至 于 不 得 不 担心 服务 器 资源 的 站 点 ， 也 有 必要 担心 
站 点 的 安全 性 。 如 果 表 单 访问 的 是 数据 库 ， 就 非常 有 必要 采用 服务 器 端的 验证 。 在 服务 器 
验证 表单 的 一 种 好 的 方式 是 : 把 表单 传 给 它 自己 ， 而 不 是 跳 转 到 不 同 的 页 面 。 这 样 用 户 就 
可 以 在 同一 张 表单 页 面 中 得 到 错误 信息 。 用 户 也 就 更 容易 发 现 错误 了 。 

EPE 单 击 页面 中 的 “查看 ”按钮 ， 切 换 至 “标签 检查 器 ”选项 卡 ， 单 击 “ 行 为 ” 

面板 下 的 [zs 按钮 ， 从 弹出 的 下 拉 菜单 中 选择 “ 转 到 URL” 选 项 ， 如 图 6-28 所 示 。 


对 员 加 下 些 洲 脂 节 狂 落 此 二 




















图 6-28 选择 “ 转 到 URL” 


E> 弹出 “ 转 到 URL” 对 话 框 , 在 URL 文本 框 中 输入 要 转 到 的 文件 “voteok.php”， 
如 图 6-29 所 示 ， 然 后 单 击 [_ 确定] 按钮 ， 完 成 “ 转 到 URL” 的 设置 。 




















图 6-29 输入 “ 转 到 URL” 的 文件 地 址 
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3.2 设计 计算 投票 页 面 的 功能 


计算 投票 页 面 为 voteadd.php， 主 要 方法 是 接收 vote.php 所 传递 过 来 的 参数 ， 然 后 再 进 


行 累 加 计算 。 计 算 投票 页 面 voteadd.php 只 用 于 后 台 计算 ， 投 票 者 在 成 功 投票 之 后 转 到 投票 
结果 页 面 voteok php， 只 要 加 入 代码 header(“location:voteok.php”): 到 voteadd php 页 面 , 就 可 
以 完成 对 voteadd.php 页 面 的 制作 ， 本 节 的 核心 代码 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<?php 
i (ompty ts POSTET LDA 
echo "您 没 选择 投票 的 项 目 "; 
exit (0); 
} // 判 断 是 否 选择 了 投票 的 选项 
else 
{ 
$ID = strvall($ POST[L7ID7]) 7 
// 赋 值 ID 变量 为 上 一 页 传递 过 来 的 ID 值 
$conn = mysql connect ("localhost", "root", "admin"); 
// 建 立 数据 库 连接 
if (!$conn) 
{ 
die(' 数 据 库 连 接 出 错 : ' . mysql error()); 


3 
// 如 果 数据 库 连 接 出 错 ， 显 示 错 误 
mysql select db("vote", $conn); 


// 查 询 vote 数据 


mysql query ("UPDATE vote SET vote = vote + 1 WHERE ID = '".S$SID."'") 7 
// 根 据 ID 更 新 数 表 vote， 并 自动 加 1 


mysql close(Sconn) 7 


header ("location:voteok.php"); 
// 转 到 voteok.php 
} 
UPDATE 语句 用 于 在 数据 库 表 中 修改 数据 。 语 法 如 下 : 


UPDATE table name 
SET column name = new value 
WHERE column name = some value 


因为 SQL 对 大 小 写 不 敏感 ， 所 以 UPDATE 与 update 等 效 。 
为 了 让 PHP 执行 上 面 的 语句 ， 我 们 必须 使 用 mysql_query0 函 数 。 该 函数 用 于 向 SQL 


连接 发 送 查 询 和 命令 。 
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3.3 ”显示 投票 结果 的 页 面 


显示 投票 结果 页 面 voteok.php 主要 是 用 来 显示 投票 总 数 结果 和 各 投票 的 比例 结果 ， 静 
态 页 面 的 设计 效果 如 图 6-30 所 示 。 


央 ci\apache\htdocs\ votelvoteck php* = 





闻 贡 丑 弄 特 瞪 淋 山 虽 酒 凡 烘 贱 
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6-30 ”显示 结果 页 面 的 设计 效果 


ED 新 建文 档 voteok.php， 页 面 属性 设置 为 :背景 颜色 #CCCCCC， 字 体 大 小 12， 
上 边 距 0， 其 他 默认 。 在 页 面 中 插入 3x3 表格 ， 宽 度 550， 居 中 对 齐 ， 各 行 高 度 分 
别 是 30、208 和 30。 分 别 合并 第 一 行 、 第 三 行 ， 设 置 背 景色 #66CC00， 在 第 一 行 
单元 格 内 输入 “选项 调查 中 总 共有 人 参加 投票 ! ”文字 内 容 。 

ED 设置 第 二 行 的 背景 色 为 本 FFFFF， 第 一 、 第 三 单元 格 的 宽度 为 40， 在 第 二 行 
的 第 二 单元 格 中 插入 表单 ， 在 表单 内 插入 3x3 表格 ， 宽 度 85%， 边 框 1， 居 中 对 
齐 ， 各 行 高 度 分 别 是 20、25、20。 分 别 合并 第 一 行 、 第 三 行 ， 在 第 一 行 输入 “ 投 
票 结果 : ”， 在 第 三 行 插入 “返回 ”按钮 ， 设 置 动 作为 “ 重 设 表 单 ”， 按 钮 名 称 
为 “Submit”， 值 是 “返回 ”。 

EGRB) 单 击 “ 绑 定 ” 面 板 上 的 [ 国 按钮 ， 从 弹出 的 下 拉 菜单 中 选择 “记录 集 (查询 )” 选 
项 ， 在 打开 的 “记录 集 ” 对 话 框 中 ， 进 行 如 图 6-31 所 示 的 设置 。 

同上 一 步 创 建 记录 集 Rs1， 在 记录 集 对 话 框 中 单 击 [高] 按钮 ， 进 入 高 级 
编辑 窗口 ， 并 在 SQL 对 话 框 中 加 入 以 下 代码 : 


SELECT suml(vote) as sum 

// 选 择 vote 字段 进行 合计 计算 ， 函 数 sum () 用 于 计算 总 值 
FROM vote 

// 从 数据 表 vote 中 取出 数据 


单 击 于 本 一] 按钮 ， 完 成 记录 集 的 设置 ， 如 图 6-32 所 示 。 
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图 6-31 设置 “记录 集 ” 属 性 


名 称 ; 8] 
连接 : | vote 


SQL: SELECT sun(vote) as s 
RON vote 

















加 网 视图 
田 类 预存 过 和 


























图 6-32 “记录 集 ” 对 话 框 的 设置 


EEe 展开 Rs 记录 集 , 把 item 字段 拖 入 第 二 行 的 第 一 个 单元 格 , 在 第 二 个 单元 格 中 
插入 图 像 bar.gif， 在 第 三 个 单元 格 中 输入 文字 “小 计 : 票数 ”， 把 vote 字段 拖 入 
文字 “票数 ” 前， 展开 记 录 集 Rs1， 把 sum 字段 拖 入 (外 表格 ) 第 一 行 单元 格 文字 中 
的 “有 人 ”两 字 之 间 ， 如 图 6-33 所 示 。 

TRY 单 击 [代码 | 掖 钮 ， 进 入 “代码 ”视图 编辑 页 面 ， 在 “代码 ”视图 编辑 页 面 中 
找到 如 下 代码 : 


<?php echo $row Rs['vote']; ?> / <?php echo $row Rsl['sum']; ?> 


// 相 应 百分比 的 代码 
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出 c:-\apacns\htdocsivoteivotsck phps -Dx 1 
TERED vote php 在 
线 
5 四 《 
Resim) |[ 二 (Rssots} (Rslsom)% [小 计 ，。 各 svote} 票数 tf 系 
EE : 
计 
(< 
5 
Gody> table> Ctr> Ctd> Cform#fornl> [WI A lo% v723x362v 6K71 秒 Unicode (TF-8) 

















图 6-33 ”字段 的 插入 

按 下 的 面 步 又 修改 此 段 代码 。 

@ 去 掉 “/” 前 面 的 ?> 和 “/” 后 面 的 “<?php”， 得 到 如 下 代码 : 

<?php echo $row Rs['vote']/$row Rsl['sum'] ?> 

@ 把 “<?php echo” 和 “?>” 之 间 的 代码 用 括号 括 上 ， 得 到 如 下 代码 : 

<?php echo ($row Rs['vote']/$row Rsl['sum']) ?> 多 

图 在 代码 后 面 加 入 “*100”， 得 到 如 下 代码 : 

<?php echo ($row Rs['vote']/Srow_ Rsl['sum']) * 100 ?> $ 

@ 在 代码 前 面 加 入 “round”， 在 “*100” 前 面 加 入 小 数 点 保留 位 数 4， 并 用 括 
号 括 上 ， 得 到 如 下 代码 : 

<?php echo round(($row Rs['vote']/$row Rsl['"sum'])，4)*100 ?>% 

国 于 BY 代码 修改 之 后 ， 因 为 控制 网 页 中 的 长 度 也 是 用 到 这 段 代码 ， 所 以 将 这 段 代码 
进行 复制 ， 然 后 再 单 击 [ 代 吗 | 按 钮 ， 切 换 到 “代码 ”窗口 ， 选 择 <img> 中 的 width 
的 值 ， 将 其 代码 进行 粘贴 ， 因 为 在 图 案 中 没有 用 到 小 数 点 的 设置 ， 所 以 将 代码 前 
面 的 round 和 保留 位 数 4 删除 ， 得 到 的 代码 为 : 


width= "<?php echo round((S$row_ Rs[' vote'] /$row Rsl['sum']),4)*100 ?2>%" 


这 样 ， 图 像 就 可 以 根据 比例 的 大 小 进行 宽度 的 缩放 了 ， 具 体 设 置 如 图 6-34 所 示 。 
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ne 








RENE vote php 





人 @ 此 页 面 可 能 具有 仅 可 由 服务 器 搜索 到 的 动态 相关 文件 。 控 索 | 首选 考 数 


<cable width="85$” 上 










gn="center”cellpadding="0”cell1apacing="0" 


rd heighr="20”colspan="3”bgcolor="#FEFFEF"><apan class="STYLE1">Enbsp;<apan 
clasa="STYLE6"> 投 票 结果 : </span></span></td> 
</tr> 
<?php do { ?> 
<rz bgcolor="#FFEFFE"> 
<td width="184" height="25">c1abel><span class="STYLE3">énbsp; <?php echo $ 
row Ra['item']; ?></span></1 td> 
<rd width="408">Enbsp;<ing src="images/bar.gif” WEE TT EE] 
height="13" /><span class="STYLE3"> 
<?Php echo round( {$row Rs['voce']/$row Ral['sum']),4)*1007>%</span></td> 
<td width="424” class="SIYLE3">énbsp; 小 计 : <?php echo srow_Ra['voce']; ?> 票数 





Enbsp; </td> 
/tr> 
<?php } while (srow Rs = mysql fetch assoc($Rs)); ?> 
<tr bgcolor="#FFFFFF"> 





Rn 0 en Cr Rine) Tk/1 秒 Unicode (WTF-6) 


于 |e 回 





十 











图 6-34 设置 图 像 的 缩放 


EC 单 击 [ 测 按钮 ， 回 到 “设计 ”编辑 窗口 ， 加 入 “服务 器 行为 ”中 的 
域 ”命令 ， 选 择 voteok php 页 面 中 需要 重复 的 表格 ， 如 图 6-35 所 示 。 


同 c:\apachs\htdcesivoreivotsck phps 


“重复 区 
























小 计 ， 很 svote} 票数 














body》 Ctable> Ctr> Ctd> Cform#forml> <table> Rtr5 [NW J A ioox 


v802 x 306v 6 K/ 1 秒 Unicode (UTF-8) 














图 6-35 选择 需要 重复 的 表格 


EGG 单 击 “应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”标签 上 的 [区 按钮 ， 在 弹出 的 
下 拉 菜 单 中 选择 “重复 区 域 ” 选 项 ， 在 打开 的 “重复 区 域 ” 对 话 框 中 设 定 显示 Rs 


记录 集中 的 所 有 记录 ， 如 图 6-36 所 示 。 


单 击 L_ 型 宇 “ j 按 钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 的 区 域 左 上 角 出 现 了 一 





个 “重复 ”灰色 标签 ， 这 表示 已 经 完成 设置 。 


| 绸 二 








7 

在 

线 

报 

票 

管 

系 

县 

图 6-36 “重复 区 域 ”对 话 框 贸 

EPE 单 击 页 面 中 的 “返回 ”按钮 ， 打 开 “ 标 签 检查 器 ”面板 ， 单 击 | 在 为 ,标签 ， 再 时 


单 击 面板 上 的 [+ 按钮 , 从 弹出 的 下 拉 菜 单 中 选择 “ 转 到 URL” 选 项 , 在 打开 的 “ 转 
到 URL” 对 话 框 的 URL 文本 框 中 输入 要 转 到 的 文件 “vote.php”， 如 图 6-37 所 示 。 


打开 在 : 


VRL: vote.php 








6-37 ”输入 转 到 URL 的 文件 地 址 


E65 对 E> 单 击 [_ 确 E_ | 核 钮 ， 完 成 显示 结果 页 面 voteok.php 的 设置 ， 测 试 浏览 效果 如 
图 6-38 所 示 。 


潮 投票 主页 面 -~ Wicrosoft Internet Explorer 
文件 @) ”编辑 区) 查看 WD” 收藏) 工具 CD) 帮助 人 D 
地 址 ) | 和 图 http://127.0.0.1:8080/vote/voteok php 二 输入 关键 词 搜索 口 司 




















图 Internet 


图 6-38 ”显示 投票 结果 页 面 的 效果 
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3.4 ”防止 页 面 刷新 功能 


票 管理 系统 要 求 公平 、 公 正 地 投票 ， 不 允许 进行 多 次 投票 ， 所 以 在 设计 投票 开始 系 
统 时 ， 有 必要 加 入 防止 页 面 刷 新 的 功能 。 
实现 该 功能 的 详细 操作 步骤 如 下 。 
ED 打开 开始 投票 页 面 votephp， 把 光标 放 在 表单 中 ， 从 菜单 栏 中 选择 “插入 ”一 
“表单 ”一 “隐藏 域 ”命令 ， 插 入 一 个 隐藏 字段 “voteip”。 
ED 单 击 隐藏 域 图 图 标 ， 打 开 “ 属 性 ”面板 。 设 置 隐藏 域 的 值 为 “<?php echo 
$_SERVER[ 了 EMOTE ADDR'”]; ?>”， 取 得 用 户 人 P 地 址 ， 如 图 6-39 所 示 。 











Nl 隐痛 区 域 


voteip ] 值 D | 人 ?php echo $_SERVER[ RENOTE_ADDR 儿 








6-39 设置 隐藏 域 的 值 


ED) 将 实现 防止 刷新 的 程序 放 到 voteadd.php 页 面 里 面 。 新 建 voteadd.php( 计 算 投票 ) 
页 面 ， 在 相应 的 位 置 加 入 代码 ， 如 图 6-40 所 示 。 











图 6-40 加 入 防止 刷新 的 代码 
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具体 的 代码 分 析 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<?php 
if (empty($ POST['ID'])) { 
echo "您 没 选择 投票 的 项 目 "; 
exit (0); 
} // 判 断 是 否 选择 了 投票 的 选项 
else { 
$voteip = strval($ POST['voteip']); 
/7 赋值 变量 voteip 为 上 一 页 传递 过 来 的 voteip 值 
$con = mysql connect ("localhost", "root", "admin"); 
// 建 立 数据 库 连接 
Ef (Scony 开 
die(' 数 据 库 连 接 出 错 : ' . mysql error()); 
} // 如 果 数 据 库 连 接 出 错 ， 显 示 错 误 
mysql select db("vote"，$con); // 查 询 vote 数据 库 


| 寺 贰 


对 员 加 下 娄 些 洲 脂 荫 狂 落 卜 二 


$sql = mysql query("select * from ip where voteid = '".$voteip."'"); 


// 以 voteid = voteip 为 条 件 查询 数据 表 ip 
$info = mysql fetch array($sql); 
// 从 结果 集中 取得 一 行 作为 关联 数组 info 
if($info == true) {  // 如 果 值 为 真 ， 说 明 数 据 库 中 有 IP 地 址 ， 已 经 投 过 票 
header ("location:sorry.php"); // 转 到 voteok.php 
exit; 
} else { // 如 果 没 有 ， 则 将 IP 地 址 插入 到 ip 数据 表 中 
mysql query ("INSERT INTO ip (voteid) VALUES ('".$voteip."')"); 
} 
mysql closel($con); 
$ID = strval($ POST['ID']); 
// 赋 值 ID 变量 为 上 一 页 传递 过 来 的 ID 值 
$conn = mysql connect ("localhost", "root", "admin"); 
// 建 立 数 据 库 连接 
if (!$conn) 
{ 
die (' 数 据 库 连接 出 错 : ' . mysql error()); 
} // 如 果 数 据 库 连接 出 错 ， 显 示 错 误 
mysql select db("vote"，$conn); // 查 询 vote 数据 


mysql_query ("UPDATE vote SET vote = vote + 1 WHERE ID = "".SID."'") 7 


// 根 据 ID 更 新 数 表 vote， 并 自动 加 1 

mysql close ($conn) 7 

header ("location:voteok.php"); // 转 到 voteok.php 
} 
2 


完成 防止 页 面 刷新 设置 。 当 用 户 再 次 投票 时 ， 系 统 可 以 根据 P 的 唯一 性 进行 
判断 。 当 用 户 再 次 投票 的 时 候 , 将 转 到 投票 失败 页 面 sorry.php, 页 面 设计 如 图 6-41 


所 示 。 
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下 投票 失败 - Microsoft Internet Explorer 
文件 人 ) ”编辑 他) 查看) 收藏 和 工具 帮助 0 
地 址 0) 天 http://127.0.0.1:8080/votefsorry. php 





对 不 起 ， 你 已 投 过 一 次 票 了 ， 请 不 要 多 次 投票 
回 主页 面 查看 结果 








6-41 投票 失败 页 面 的 效果 


在 sorry.php 页 面 中 有 两 个 页 面 链接 ， 选 中 文本 后 ， 分 别 在 属性 面板 中 设置 “ 回 主页 面 
链接 到 vote php、“ 查 看 结果 ”链接 到 voteok.php 即 可 。 


国 ] 4| 在 线 投票 管理 系统 的 测试 


投票 管理 系统 设计 完成 之 后 ， 可 以 对 设计 的 系统 进行 测试 ， 按 下 F12 键 或 打开 正 浏览 
器 ， 输 入 http:/127.0.0.1/vote/vote .php， 即 可 开始 进行 测试 。 测 试 步骤 如 下 。 
ES 打开 Dreamweaver 中 的 votephp 文件 ， 开 始 投票 页 面 的 效果 如 图 6-42 所 示 。 











习 投票 主页 面 - Hicrosoft Internet Explorer 
文件 @) 编辑 于 ) 查看 WW) 收藏) 工具 GD) 帮助 0 
地 址 中) 者 http://127.0.0.1:8080/vote/vote. php 输入 关键 词 搜索 口 图 | 


PHP 投 票 管理 系统 ” 选择 您 的 最 现 ， 投 出 公正 一 村 ! 


yh 





请 你 投票 + ? 本 投票 只 可 投票 一 次 ? 


你 投 的 选项 是 : 








图 6-42 打开 的 开始 投票 页 面 
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、 : « » 二 “你 沿 : 1L 
不 选择 任何 选项 ， 单 击 “ 投 票 ”按钮 ， 则 出 现 提示 “您 没 选择 投票 的 项 目 ”， 
如 图 6-43 所 示 。 丰 
i 要 
ELS IAEA | 票 
文件 四 蝙 辑 区) 查看 Q)。 收 诚 和 ) 工具 CI) 帮助 0 管 
地 址 四 ) | 件 http:7/127.0.0.1:8080/voteyvoteadd php 
您 没 选择 投票 的 项 目 统 
宇 
倒 
的 
丽 
计 








6-43 ” 没 选择 项 目的 错误 提示 


ES 选择 投票 箱 中 的 其 中 一 项 ， 再 单 击 “ 投 票 ” 按 钮 ， 开 始 投票 。 

单 击 “ 投 票 ”按钮 后 ， 打 开 的 页 面 不 是 voteaddphp， 因 为 voteadd.php 只 是 计 
算 投 票数 的 一 个 统计 数字 页 面 ， 打 开 的 页 面 是 显示 投票 结果 页 面 voteokphp， 
voteok.php 页 面 是 voteadd.php 转 过 来 的 一 个 页 面 ， 效 果 如 图 6-44 所 示 。 

池 投票 主页 面 -~ Hicrosoft Internet Explorer 


文件 @) ”编辑 下 ) 查看 WW) 收藏 由 ) 工具 CI) 帮助 0 
地 址 四) | 件 ] http://127.0.0.1:8080/vote/voteok php 





大 Internet 





图 6-44 显示 投票 结果 页 面 的 效果 


EIB 单 击 “ 返 回 ” 按 钮 ， 回 到 投票 页 面 vote.php 中 。 当 用 户 试图 再 次 投票 时 ， 将 打 
开 投 票 失败 页 面 sorry.php， 如 图 6-45 所 示 。 
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当 投票 失败 - Hicrosoft Internet Explorer 
; 文件 下) 编辑 是) 查看 中。 收 阅 刀 ) 工具 C) 帮助 0 [1 
地址) 篇 http://127.0.0.1:8080/vote/sorry. php < 输入 关键 词 搜索 口 加 








对 不 起 ， 你 已 投 过 一 次 票 了 ， 请 不 要 多 次 投票 ? 
回 主页 面 查看 结果 








6-45 ”提示 已 经 投票 


通过 上 面 的 测试 ， 说 明 该 管理 投票 系统 的 所 有 功能 已 经 开发 完毕 。 
读者 可 以 看 到 ， 在 线 投票 管理 系统 的 开发 并 不 难 ， 用 户 可 以 根据 需要 修改 投票 的 选择 
项 ， 经 过 修改 后 的 投票 系统 可 以 适用 于 任何 大 型 网 站 。 
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模块 七 


新 闻 管 理 系统 实例 的 设计 


新 闻 管理 系统 主要 实现 对 新 闻 的 分 类 、 发 布 ， 模 拟 一 般 新 闻 媒 介 
的 发 布 过 程 。 

新 闻 管 理 系统 的 作用 就 是 在 网 上 传播 ， 通 过 对 新 闻 的 不 断 更 新 ， 
让 用 户 及 时 了 解 行 业 信息 、 企 业 状 况 以 及 需要 了 解 的 一 些 知 识 。 

以 PHP 实现 这 些 功能 相对 比较 简单 ， 涉 及 的 主要 操作 就 是 访问 
者 的 新 闻 查 询 功 能 ， 以 及 管理 员 对 新 闻 的 新 增 、 修 改 、 删 除 功能 。 

本 例 就 来 介绍 使 用 PHP 开发 一 个 新 闻 管 理 系统 的 方法 。 


。 本 模块 的 任务 重点 。 





新 闻 管理 系统 网 页 结构 的 整体 设计 

新 闻 系 统 数 据 库 的 规划 

新 闻 管理 系统 前 台新 闻 的 发 布 功 能 页 面 制作 
新 闻 管理 系统 分 类 功能 的 设计 

新 闻 管 理 系统 后 台新 增 、 修 改 、 删 除 功 能 的 实现 
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二 1| 新 闻 管理 系统 的 规划 


使 用 PHP 开发 新 闻 管 理 系统 ， 在 技术 上 主要 体现 为 如 何在 首页 上 显示 新 闻 内 容 ， 以 及 
对 新 闻 及 新 闻 分 类 的 修改 和 删除 。 一 个 完整 的 新 闻 管 理 系统 共 分 为 两 大 部 分 ， 一 是 访问 者 
访问 新 闻 的 动态 网 页 ， 二 是 后 台 管理 者 对 新 闻 进 行 编辑 的 动态 网 页 。 


1.1 系统 的 页 面 设 计 


在 本 地 站 点 上 建立 站 点 文件 夹 ews， 用 于 存放 制作 的 新 闻 管理 系统 文件 夹 和 文件 ， 如 
图 7-1 所 示 。 





篇 C:\apache\htdocs\news 
文件 中) 编辑 区) 查看 W) 收 褒 ) 工具 CD) 帮助 中) 
GER -和 邱 甩 拉 马 文 人 天 回 - 


地 址 加 ) | 回 C;\apache\htdocs\news 


文件 和 文件 夹 任务 

加 委 一 个 新 文件 天 

@ iT 
| 

局 共 此 文件 天 


EE 








图 7-1 站 点 规划 文件 夹 和 文件 
本 系统 页 面 共有 11 个 ， 整 体系 统 页 面 的 功能 和 文件 名 称 如 表 7-1 所 示 。 
表 7-1 新 闻 管 理 系统 中 各 网 页 的 功能 














页 面 功 能 
index.php 显示 新 闻 分 类 和 最 新 新 闻 页 面 
type.php 显示 新 闻 分 类 中 的 新 闻 标 题 页 面 
newscontent.php 显示 新 闻 内 容 页 面 
admin lobin.php 管理 者 登录 页 面 
admin.php 管理 新 闻 主 页 面 
news add.php 增加 新 闻 的 页 面 








news_upd.php 修改 新 闻 的 页 面 
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模 

块 

续 表 七 

页 面 功 能 可 
news_del.php 删除 新 闻 的 页 面 管 
type_add.php 增加 新 闻 分 类 的 页 面 四 
让 修改 新 闻 分 类 的 页 面 入 
type_deLphp 删除 新 闻 分 类 的 页 面 
奶 

计 


1.2 系统 的 美工 设计 


本 新 闻 管 理 系统 实例 在 色调 上 选择 蓝 色 作为 主 色调 ， 网 页 的 美工 设计 相对 比较 简单 ， 
完成 的 新 闻 系 统 首页 index.php 的 效果 如 图 7-2 所 示 。 


本 沽 @) 查看 多 尝 由 工具 C) 帮助 由) 
Mt3://127.0. 0. 1 E00/mers/ indexl sh 


PHP 新 闻 系统 


01503.03 





20150303 








图 7-2 首页 index.php 的 效果 
新 闻 管理 系统 后 台 也 是 重要 的 ， 登 录 后 台 的 效果 如 图 7-3 所 示 。 


(NEWS 


PHP 新 闻 系统 / 






7-3 ”后 台 管理 页 面 的 效果 
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2 | 系统 数据 库 的 设计 


制作 一 个 新 闻 管理 系统 时 ， 首 先 要 设计 一 个 储存 新 闻 内 容 、 管 理 员 账号 和 密码 的 数据 
库 文件 ， 方 便 管理 人 员 对 新 闻 数 据 信息 进行 管理 和 完善 。 


2.1 新 闻 数 据 库 设计 


新 闻 管 理 系 统 需要 一 个 用 来 存储 新 闻 标 题 和 新 闻 内 容 的 新 闻 信 息 表 news， 还 要 建立 一 
个 新 闻 分 类 表 newstype 和 一 个 管理 信息 表 admin。 
制作 步骤 如 下 。 
ED 在 phpMyAdmin 中 建立 数据 库 news, 单 击 “数据 库 ” 命令 蜗 数 据 库 打开 本 地 
的 “数据 库 管 理 页 面 ”， 在 “新 建 数据 库 ” 文 本 框 中 输入 数据 库 名 称 “news”， 
单 击 后 面 的 数据 库 类 型 下 拉 菜 单 ， 从 弹出 的 选择 项 中 选择 “utf8_bin”,， 单 击 四 到 按 
钮 ， 返 回 “常规 设置 ”页 面 ， 在 数据 库 中 就 建立 了 news 数据 库 ， 如 图 7-4 所 示 。 














otsAamin per ans 
回回 上 加 nr Wsor 








泡 新 建 数据 库 加 
































d= utf8_bin Ee 区 下 
图 lySQL 连接 校对 : utf8_general_ci “I@ ! 











7-4 ”创建 news 数据 库 


单 击 左边 的 news 数据 库 将 其 连接 上 ， 打 开 “ 新 建 数 据 表 ” 页 面 ， 分 别 输 入 数 
据 表 名 “news”、“newstype” 和 “admin”， 即 创建 3 个 数据 表 。 创 建 的 news 
数据 表 如 图 7-5 所 示 。 输 入 数据 域名 以 及 设置 数据 域 位 的 相关 数据 ， 数 据 表 news 
的 字段 说 明 如 表 7-2 所 示 。 

创建 newstype 数据 表 ， 用 于 储存 新 闻 分 类 ， 输 入 数据 域名 以 及 设置 数据 域 位 
的 相关 数据 ， 如 图 7-6 所 示 。newstype 数据 表 的 字段 及 说 明 如 表 7-3 所 示 。 
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新 闻 分 类 编号 


新 闻 加 入 时 间 























他 
于 
pe 
a a 
Cay 日 
ma wo mm 和 
EE 

















7-5 创建 的 news 数据 表 


表 7-2 新 闻 数 据 表 news 


news id 


news title 


news_content 
news_date 


news_author 



































































































ET ez Exploror 
Er Tr 十 
Sti 0) | 图 My /2.0.0 1 mn/ Phpmmh ssnder Po7 low ert Tm heres Lhd Axis 口 加 | 

phpMgAdmnin localhon 中 mo， mowsiype 
区 ， 让 外 榴 “加 SQL 大捷 过 了 产 入 。 医 导出 荡 导 和。 区 入 作 。 图 尘 空 ”天 除 
机 回回 回回 一 
岂 已 成 功 眉 以 未 newstype 
有 TD 

ee 下 1 [证 PHP ft ] 

ee 3 类 型 as 之 芝 bd 可 作 
口 weld ia 人 再 无 AUTOINCREMENT 加 几 X 辐 呈 吻 

Be 口 wpe_name vachas0) Wagereaie 下 天 国 恩 交 国 图 国 

个 全 元 /全 不 运 六 入 国志 XXX 国 四 

各 打字 议和 轿 规 划 玫 结 村 加 

亲 关 in 1 。 下 加 于 二 挟 O 于 天 开关 O 于 之 [ps4 ”六 区 卫 ] 目 

素 引 @ 

天 作 证 名 美 于 瞪 一 要 要。 字段” 芭 数 空 蔡 旦 

及 X PRMARY BIREE 是 可 pad 0 和 

在 1 人 es| [FT] 

LL 更 

站 EL 和 Et 


图 7-6 创建 newstype 数据 表 
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表 7-3 新 闻 分 类 数据 表 newstype 


意义 字段 名 称 数据 类 型 字段 大 小 必 填 字段 
主题 编号 tfype id integer 
新 闻 分 类 type_name varchar 


四 YY 创建 admin 数据 表 ， 用 于 后 台 管 理 者 登录 验证 用 ， 输 入 数据 域名 以 及 设置 数 
据 域 位 的 相关 数据 ， 如 图 7-7 所 示 。 
127- 0.0-1:800 / localhost / news / adain | phplyAdain 3.3.7 一 Nicrosoft Internet Explorer 


文件 中) ”编辑 到 ) 查看 WD 收藏 全 ) 工具 GD) 帮助 
地 址 中 | 罩 http://127.0.0. 1;600/phplyAaninyindex php?db=newsAtoken=053bOb70e54453596472617443155cb4phpllyAdnin=ulhnStt158sapucf2nn3Tbseandll 





并 | 和 








加 localhost ， 成 news， 国 admin 
半 剂 览 。 队 结构 “型 SQL 卢杰 索 关 亲 入 障 叶 出 ” 阐 导 入 货 操 作 ， 硬 清空 “ 涡 副 除 
已 字段 类 型 整理 本 EL 如 额外 









































Di int(11) AUTO_INCREMENT 
口 usermame varchar(50) ut8_general_ci 否 
口 password varchar(50) utfB_general_ci 否 
企 _ 全 选 /全 不 选 羡 # 磷 : 国 少 X 图 加 田园 


各 打印 预览 咯 规划 瑟 结 构 加 
屠 洪 加 [1 | 个 字段 @ 寺 表 结尾 C) 于 表 开 头 O 〇 于 之 后 | 记 Ea 








素 引 : @ 


操作 键 名 类 型 ”唯一 紧 资 字段 基数 整理 空 注释 
及 X PRIMARY BTREE 是 否 id A 





在 第 [1 个 字段 创建 索引 [现行 ] 











+ 详细 








7-7 创建 的 admin 数据 表 
admin 数据 表 的 字段 及 说 明 如 表 7-4 所 示 。 
表 7-4 管理 信息 数据 表 admin 
必 填 字段 








在 创建 上 述 数据 表 时 ， 其 中 有 的 涉及 到 新 闻 保 存 时 的 时 间 问 题 ， 使 用 PHP 实现 获取 系 
统 默认 即时 时 间 ， 可 以 使 用 两 种 方法 ， 一 种 是 在 网 页 PHP 中 用 date0 和 time() 函 数 来 实现 
另 一 种 是 直接 取 MySQL 数据 库 中 的 NowO 时 间 , 考虑 到 因为 后 期 数据 量 大 需要 减少 服务 器 
工作 量 ， 我 们 优先 采用 在 网 页 使 用 PHP 获取 时 间 的 方法 ， 具 体 的 实现 方法 在 新 增 新 闻 页 面 
的 设计 时 会 讲解 到 。 
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2.2 创建 系统 站 点 


在 Dreamweaver CS5.5 中 创建 一 个 “新 闻 管理 系统 ”网 站 站 点 news， 由 于 这 是 PHP 数 
据 库 网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 7-5 所 示 。 


表 7-5 站 点 设置 参数 





守 友 丑 弄 特 瞪 淋 须 咀 画 亨 语 红 项 








站 点 名 称 news 
本 机 根 目 录 Ci\apache\htdocs\news 
测试 服务 器 Ci:\apache\htdocs 
网 站 测试 地 址 http://127.0.0.1/news 
MySQL 服务 器 地 址 Ci\apache. MySQL-5.0.90\data\news 
管理 账号 /密码 root/admin 
数据 库 名 称 news 
创建 news 站 点 的 具体 操作 步骤 如 下 。 


首先 在 C:\apache\htdocs 路 径 下 建立 news 文件 夹 , 系统 所 建立 的 网 页 文件 都 将 
存放 在 该 文件 夹 下 ， 如 图 7-8 所 示 。 


篇 C:\apache\htdocs 
文件 @) 编辑 是) 查看 WW) 收藏 和) 工具 CD) 帮助 0D) 
昌 慨 日 - 什 吕 扫 当 已 文人 天 国 - 

地 址 加 C:\apache\htdocs 


文件 和 文件 夹 任务 y . 


详细 信息 > 





7-8 建立 站 点 文件 夹 news 


EDp) 运行 Dreamweaver CS5.5， 选 择 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 
开 “ 管 理 站 点 ”对 话 框 ， 如 图 7-9 所 示 。 

















图 7-9 “管理 站 点 ”对 话 框 
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对 话 框 的 左边 是 站 点 列表 框 , 其 中 显示 所 有 已 经 定义 的 站 点 。 单 击 [器 诗 甸 .| 按 
钮 ， 打 开 “ 站 点 设置 对 象 ”对 话 框 ， 进 行 如 图 7-10 所 示 的 参数 设置 。 


站 点 设置 对 象 news 


Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 文件 和 资源 的 集合 。 Dreamweaver 
站 点 通常 包含 两 个 部 分 : 可 在 其 中 存储 和 处 理 文件 的 计算 机 上 的 本 地 文件 
夹 ， 以 及 可 在 其 中 将 相同 文件 发 布 到 Web 上 的 服务 器 上 的 远程 文件 夹 。 


您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 。 
站 点 名 称 : | news 
本 地 站 点 文件 夹 ; | C: pachehtdocsmews\ 









































7-10 ”建立 news 新 闻 站 点 


EEC 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 [出 ， 打 开 “ 基 
本 ”选项 卡 进 行 如 图 7-11 所 示 的 参数 设置 。 


设置 来 自 








医道 拱 敌 Wieb 闪 发 





C:\ppache\htdocs 

















s [http://127.0.0.1/ 测试 





















































图 7-11 “基本 ”选项 卡 的 设置 
ERe 设置 后 ， 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 界面 ， 选 中 “ 维 
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护 同步 信息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 选择 “PHP MySQL”， 表 
示 是 使 用 PHP 开发 的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 7-12 所 示 。 





Es = EE 





可 维护 同步 信息 医道 做 Ww 并 发 
口 保存 时 自动 格 广 件 上 传 到 服务 器 
口 启用 文件 取出 功能 
加 打开 文件 之 前 职 出 EE 
职 出 名 称 : | 
电子 邮件 地 址 : 


玫 码 加班 类 些 洲 册 画 避 ” 帮 剧 需 






















































































图 7-12 设置 “高 级 ”选项 卡 


ED 单 击 [保本 “| 按钮 ， 返 回 “ 服 务 器 ”设置 界面 ， 选 中 “测试 ” 复 选 框 ， 如 
图 7-13 所 示 。 


站 点 设置 对 象 news 


您 将 在 此 位 置 选 择 承 载 web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 
Internet 服务 提供 商 (ISP) 或 Web 管理 员 。 


糙 度 : 要 下 好 王 Dreamweaver 好 认 上 工作 ， 傅 无 洞窟 成 此 共 因 .向 轨 要 道 扫 乔 Web 六 发 
布 页 历 ， 您 只 再 记 义 一 个 加 要 万 务 导 即 可 - 












































图 7-13 选中 “测试 ” 复 选 框 
单 击 [ ” 保 奉 ”| 按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CS5.5 中 就 
有 了 刚才 设置 的 站 点 news。 单 按钮 关闭“ 管理 站 点 ”对 话 框 ， 这 样 
就 完成 了 Dreamweaver CS5.5 测试 用 户 管理 系统 网 页 的 网 站 环境 设置 。 
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2.3 数据库 的 连接 


建立 数据 库 后 ， 要 在 Dreamweaver CS5.5 中 连接 news 数据 库 ， 连 接 新 闻 管理 系统 数据 


库 的 步骤 如 下 。 
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将 涉及 的 本 章 文 件 复制 到 站 点 文件 夹 下 ， 打 开 index1.php， 如 图 7-14 所 示 。 


DW 冲田 的 四 EE MAD BRU RO 6 加 ED YOU Rao | 








Eeea [国士 :| 吾 - 济 -| 钨 物 - 全- 区 | 的 -| 加 
自 Ht 


4 RE | 
i Er TE 





0 kT 而 Tf 放 具 衣 羽 吕 击 服 务 庆 过 过 到 失 8I 训 栖 关 卫 件 - 过 达 | 下 和 大 到 


PHP 新 闻 系 统 ， 








故人 性 
EL] 本 四 | 无 ~ 无 7 生性 芋 芋 林 BD 
ess ee - Ee Gb Hs0 

i 
































< 日 
1 下 让 地 而 访 必 中 ES 











图 7-14 打开 网 站 的 首页 
从 菜单 栏 中 选择 “窗口 ”一 “数据 库 ” 命 令 ， 打 开 “ 数 据 库 ” 面板， 在 该 面 


板 上 单 击 外 图 标 ， 并 在 打开 的 下 拉 菜 单 中 选择 “MySQL 连接 ”选项 ， 如 图 7-15 
所 示 。 





图 7-15 选择 “MySQL 连接 ” 


ES 在 “MySQL 连接 ”对 话 框 中 ， 输 入 连接 名 称 为 “news”、MySQL 服务 器 名 
为 “localhost”、 用 户 名 为 “root”、 密 码 为 “admin”。 选 取 所 要 建立 连接 的 数据 


库 ， 可 以 单 击 [过 取 .| 按 钮 浏览 MySQL 服务 器 上 的 所 有 数据 库 。 选 择 刚 建立 的 范 
例 数据 库 news， 具 体内 容 设置 如 图 7-16 所 示 。 


连接 名 称 : Inews 
WysQL 服务 器 : localhost 


图 7-16 设置 “MySQL 连接 ”的 参数 











守 友 慎 弄 特 瞪 淋 须 咀 画 亨 语 霸 渍 


EGR 单 击 Li 二] 按钮 ， 测 试 与 MySQL 数据 库 的 连接 是 否 正确 ， 如 果 正 确 ， 则 弹 


出 一 个 提示 消息 框 ， 表 示 数 据 库 连接 成 功 ， 具 体内 容 如 图 7-17 所 示 。 





7-17 设置 成 功 


ED 单 击 [_ 克 ej 按钮 ， 则 返回 编辑 页 面 ， 在 “数据 库 ” 面 板 中 显示 绑 定 过 来 的 
数据 库 ， 如 图 7-18 所 示 。 

































日 国 aewss 
日- 团 。 脚本 编制 











news 
团 newstype 
视图 

预存 过 程 


由 -由 
桨 三 四 





图 7-18 绑 定 的 数据 库 news 
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3| 新 闻 系统 页 面 


新 闻 管 理 系 统 前 台 部 分 主要 有 3 个 动态 页 面 ， 分 别 是 用 来 访问 的 首页 新 闻 主 页 面 
index.php， 新 闻 分 类 信息 页 面 ypephp， 新 闻 详 细 内 容 页 面 newscontent.php。 


3.1 新闻 系 统 主 页 面 的 设计 


在 本 节 中 主要 介绍 新 闻 管 理 系 统 的 主页 面 index.php 的 制作 ， 在 index.php 页 面 中 ， 主 
要 有 显示 最 新 新 闻 的 标题 、 加 入 时 间 、 显 示 新 闻 分 类 、 单 击 新 闻 中 的 分 类 进入 分 类 子 页 面 
查看 新 闻 等 功能 。 

制作 的 步骤 如 下 。 

EC 新 建 ndex.php 文档 ， 输 入 网 页 标题 “新 闻 首 页 ”， 在 页 面 中 插入 一 个 3x1 表 
格 A( 为 叙述 准确 ， 以 英语 字母 顺序 命名 表格 )， 宽 768， 居 中 对 齐 ， 其 他 为 0。 在 
第 一 行 单元 格 中 插入 图 片 images/top.gif, 在 第 三 行 单元 格 中 插入 图 片 images/di.gif， 
背景 色 均 设 为 性 FFFFF。 

ESD) 设置 第 二 行 单元 格 的 高 度 为 192, 背景 色 为 本 FFFFF, 插入 一 个 2x2 的 表格 B， 
宽 768， 列 宽 分 别 为 150 和 618。 合 并 表格 B 第 一 行 的 两 个 单元 格 ， 设 置 为 垂直 顶 
端 对 齐 , 插入 一 个 3x1 表格 C, 宽度 为 150。 设置 第 二 行 第 一 个 单元 格 的 宽 为 618， 
高 为 25， 在 该 单元 格 内 插入 表单 ， 再 在 表单 内 插入 一 个 1x1 的 表格 D， 宽 为 618， 
高 为 20， 背 景色 为 FFFFF。 在 表格 B 的 第 二 列 第 二 行 单元 格 内 插入 一 个 3x3 的 
表格 EE， 宽度 为 96%， 边 框 为 1， 列 宽 分 别 为 44%、37% 和 19%， 行 高 分 别 为 30、 
25、25， 合 并 第 一 行 单元 格 。 在 表格 E 下 方 插入 一 个 1x4 的 表格 ， 宽 度 为 583， 
其 他 为 0。 

ES 在 表格 B 的 第 1 行 单元 格 ， 输 入 文字 “新 闻 分 类 ”， 然 后 单 击 “ 绑 定 ” 面 板 
上 的 [| 按钮 ， 从 弹出 的 菜单 中 选择 “记录 和 集 (查询 )” 选 项 ,创建 记录 集 并 进行 如 下 
设置 : 

@ ”在 “名 称 ” 文 本 框 中 输入 “Recordset1 ”作为 该 记录 集 的 名 称 。 

e@ ”从 “连接 ”下 拉 列 表 框 中 选择 数据 源 连接 对 象 “news”。 

@ ”从 “表格 ”下 拉 列 表 框 中 选择 使 用 的 数据 库 表 对 象 为 “newstype”。 
e@ ”在 “ 列 ” 栏 中 选中 “全 部 ” 单 选 按 钮 。 

完成 的 设置 情况 如 图 7-19 所 示 。 

绑 定 记录 集 后 , 将 记录 集 相关 字段 插入 index1.php 网 页 的 适当 位 置 , 如 图 7-20 
所 示 。 
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7-19 “记录 集 ” 对 话 框 
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7-20 ”插入 到 index1.php 网 页 中 
ECD 由 于 要 在 indexl.php 页 面 中 显示 数据 库 中 所 有 新 闻 分 类 的 标题 , 而 目前 的 设 定 
只 会 显示 数据 库 的 第 一 笔 数 据 ， 因 此 需要 加 入 “服务 器 行为 ”中 的 “重复 区 域 ” 
的 命令 ， 选 择 {RecordsetLtype_name} 所 在 的 行 ， 如 图 7-21 所 示 。 





图 7-21 选择 要 重复 显示 的 一 列 
单 击 “ 服 务 器 行为 ”标签 上 的 [号 | 按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “重复 区 域 ” 
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选项 ， 并 在 打开 的 “重复 区 域 ”对 话 框 中 选中 “所 有 记录 ” 单 选 按钮 ， 如 图 7-22 
所 示 。 











7-22 ”选择 一 次 可 以 显示 的 记录 数 


革 TX 单 击 [_ 克 | 校 钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 的 区 域 左上 角 出 现 了 一 
个 “重复 ”灰色 标签 ， 这 表示 已 经 完成 了 设置 。 

除了 显示 网 站 中 的 所 有 新 闻 分 类 标题 外 ， 还 要 提供 访问 者 感 兴趣 的 新 闻 分 类 
标题 链接 ， 来 实现 详细 内 容 的 阅读 ， 为 了 实现 这 个 功能 ， 首 先 要 选取 编辑 页 面 中 
的 新 闻 分 类 标题 字段 ， 如 图 7-23 所 示 。 





7-23 ”选择 新 闻 分 类 标题 


ED 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 览 文件 ”图 标 园 ， 在 弹 
出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 ypephp， 如 图 5-24 所 示 。 


选择 文件 名 自 : 加 文件 系统 
吕 数 据 源 


查找 范围 :| 已 news 
回 newscontent .php 





:| 所 有 文件 人 要 














[tm Php 





图 7-24 选择 链接 的 文件 
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ED 单 击 [ 敦 ..， ] 护 钮 ， 设 置 超级 链接 要 附带 的 URL 参数 的 名 称 和 值 。 将 参数 名 
称 命名 为 id， 如 图 7-25 所 示 。 





和 于 世 加 弄 特 瞪 淋 须 咀 画 亨 舍 红 匡 











7-25 “参数 ”对 话 框 


ED 单 击 [_ 胡 和 E] 掖 钮 回 到 编辑 页 面 ， 主 页 面 indexl.php 中 新 闻 分 类 的 制作 已 经 
完成 ， 最 新 新 闻 的 显示 页 面 的 设计 效果 如 图 7-26 所 示 。 
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图 7-26 最 新 新 闻 的 显示 页 面 的 设计 效果 


EDP)% 单 击 “应 用 程序 ”面板 中 的 “ 绑 定 ”标签 上 的 [ 榴 按 钮 ， 从 弹出 的 下 拉 菜单 中 选 
择 “ 记 录 集 (查询 )” 选 项 ， 打 开 “ 记 录 集 ”对 话 框 ， 在 该 对 话 框 中 进行 如 下 设置 : 

在 “名 称 ” 文 本 框 中 输入 “Rel ”作为 该 记录 集 的 名 称 。 

从 “连接 ”下 拉 列 表 框 中 ， 选 择 数据 源 连接 对 象 “news”。 

从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 “news”。 

在 “ 列 ” 栏 中 选中 “全 部 ” 单 选 按钮 。 

将 “排序 ”设置 为 “news id” 一 “降序 ”。 
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设置 完成 的 情况 如 图 7-27 所 示 。 





名 称 : Rel 


















































[ 开 考 数 
排序 : [news_id 


























7-27 “记录 集 ” 对 话 框 的 设置 


ES 绑 定 “ 记 录 集 ” 后 ， 将 记录 集 的 字段 插入 到 indexl.php 网 页 的 适当 位 置 。 

由 于 要 在 indexl.php 页 面 中 显示 数据 库 中 部 分 新 闻 的 信息 , 而 目前 的 设 定 只 会 
显示 数据 库 的 第 一 笔 数据 ， 因 此 ， 需 要 加 入 “服务 器 行为 ”中 的 “重复 区 域 ”的 
设置 ， 单 击 index1.php 页 面 中 的 最 新 新 闻 标 题记 录 表 格 ， 如 图 7-28 所 示 。 
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图 7-28 单 击 选择 需要 重复 的 选区 
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ED) 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”标签 上 的 [向 | 按钮 ， 从 弹出 的 
下 拉 菜 单 中 选择 “重复 区 域 ” 选 项 ， 在 弹出 的 “重复 区 域 ” 对 话 框 中 设置 要 重复 
的 记录 条 数 (例如 10 条 )， 如 图 7-29 所 示 。 

ED 单 击 [_ 胡 按钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 的 区 域 左 上 角 出 现 了 
一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设 定 。 

EC 由 于 最 新 新 闻 这 个 功能 除了 显示 网 站 中 的 部 分 新 闻 外 ， 还 要 将 访问 者 感 兴趣 
的 新 闻 标 题 链接 至 详细 内 容 来 阅读 ， 所 以 首先 选取 “查看 ”文字 ， 如 图 7-30 所 示 。 


守 册 加 弄 特 瞪 淋 须 吸 画 亨 语 红 贡 








图 7-29 选择 一 次 可 以 显示 的 记录 数 图 7-30 选择 新 闻 分 类 标题 “查看 ” 


ECGED) 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “浏览 文件 ”图 标 园 ， 从 弹 
出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 newscontentphp, 如 图 7-31 所 示 。 


选择 文件 名 自 : G@) 文件 系统 
〇 数据 源 站 点 和 服务 器 


查找 范围 0): | 已) news 


周 aotes newscontent. php 
辐 sanin 回 tme.php 

辐 connections 

dats 

Binaees 


回 indexl.php 


文件 名 加 : 。 |newscontent. php 
文件 类 型 和) | 所 有 文件 Gt.*) 











|newscontent. php 
相对 于 | 文 尖 YW| indexl.php 
在 站 点 定义 中 更 改 默认 的 链接 相对 于 








图 7-31 选择 链接 文件 


单 击 L 要 迷 -| 按 钮 ， 设 置 超级 链接 要 附带 的 URL 参数 的 名 称 和 值 。 将 参数 名 
称 命 名 为 news id， 如 图 7-32 所 示 。 


中 PHP+MySQL 
和 动态 网 站 设计 实用 教改 

















7-32 “参数 ”对 话 框 


单 击 忆 B 按钮 回 到 编辑 页 面 ， 当 记录 集 超过 一 页 时 ,就 必须 有 “上 一 页 ”、 
“下 一 页 ”等 按钮 或 文字 ， 让 访问 者 可 以 实现 翻 页 的 功能 ， 这 就 是 “记录 集 分 页 ” 
的 功能 。“ 记 录 集 分 页 ”按钮 位 于 “插入 ”工具 栏 的 “数据 ”组 中 ， 因 此 将 “ 插 
入 ”工具 栏 由 “常用 ”切换 成 “数据 ”类 型 ， 单 击 “ 记 录 集 分 页 ”| 莉 H 工具 按钮 ， 
如 图 7-33 所 示 。 





7-33” 单 击 “ 记 录 集 分 页 ” 


EE ZE 在 打开 的 “记录 集 导航 条 ”对 话 框 中 ， 选 取 要 导航 的 记录 集 以 及 导航 条 的 显 
示 方 式 “ 文 本 ”， 然 后 单 击 [确定] 按钮 回 到 编辑 页 面 ， 会 发 现 页 面 出 现 该 记录 
集 的 导航 条 ， 如 图 7-34 所 示 。 














图 7-34 添加 “记录 集 导航 条 ” 
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ESE2》 如 果 希 望 看 到 总 共有 多 少 记 录 ， 当 前 记录 是 第 几 条 ， 那 么 必须 插入 “记录 集 导 
航 状 态 ”， 在 “插入 ”工具 栏 的 “数据 ”类 型 中 ， 单 击 “显示 记录 计数 ”[ 四 工具 
按钮 ， 在 弹出 的 快捷 菜单 中 ， 选 取 要 导航 状态 的 记录 集 为 Rel， 然 后 单 击 L_ 展 中 ] 


按钮 回 到 编辑 页 面 ， 会 发 现 页 面 出 现 该 记录 集 的 导航 状态 ， 如 图 7-35 所 示 。 
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7-35 添加 计数 器 


ESZE) index1.php 这 个 页 面 需要 加 入 “查询 ”的 功能 ， 这 样 ， 新 闻 管 理 系统 日 后 才 不 
会 出 现 因 数据 太 多 而 有 不 易 访 问 的 情形 ， 设 计 如 图 7-36 所 示 。 














图 7-36 搜索 主题 设计 


省 注意 :利用 表单 及 相关 的 表单 组 件 来 制作 以 关键 词 查询 数据 的 功能 ， 需 要 注意 
如 图 7-36 所 示 的 内 容 都 在 一 个 表单 之 中 ， “查询 主 题 ”后 面 的 文本 框 的 
命名 为 keyword，“ 查 询 ” 按 钮 为 一 个 提交 表单 按钮 。 


国 了 在 此 要 将 先前 建立 的 记录 集 Rel 做 一 下 更 改 ， 打 开 “ 记 录 集 ”对 话 框 ， 并 进 
入 “高 级 ”设置 ， 在 原 有 的 SQL 语法 中 加 入 一 段 查询 功能 的 语法 : 


WHERE news _ title like '%".$keyword."%' 


那么 以 前 的 SQL 语句 将 变 成 如 图 7-37 所 示 。 


241。 





冰 注意 : 


切换 到 代码 设计 窗口 ， 找 到 Rel 记录 和 集 相应 的 代码 并 加 入 如 下 代码 : 


$keyword = $_ POST[keyword]; 
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其 中 like 表示 进行 模糊 查询 ，% 表 示 任 意 字 符 , 而 keyword 是 个 变 





连接 : news 


SQL: SELECT * 
了 RDN news 
WHERE news_title like “和 "和 keyword “% 
ORDER BY news_id DESC 








: 国 














:| 瑟 团 表格 
田 为 视图 
田震， 预存 过 程 






































7-37 修改 SQL 语句 


定义 keyword 为 表单 中 keyword 的 请 求 变量 ， 如 图 7-38 所 示 。 
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图 7-38 加 入 代码 


ERE3 以 上 的 设置 完成 后 ，indexl.php 系统 主页 面 就 有 查询 功能 了 ， 先 在 数据 库 中 加 
入 两 条 新 闻 数 据 ， 可 以 按 下 F12 键 在 浏览 器 中 测试 一 下 是 否 能 正确 地 查询 。 
index1.php 页 面 中 将 会 显示 所 有 网 站 中 的 新 闻 分 类 主题 和 最 新 新 闻 标题 , 如 图 7-39 
所 示 。 


:文件 四 编辑 也) 查看 WD 收藏 和 ) 工具 DD) 帮助 中 


地 作 四 | 狠 Mttp;//127.0.0.1-800/ners/indexl php 





了 才 宙 加 下 焙 些 洲 冉 呈 耳 避 ” 古 英 看 “下 下 


PHP 新 闻 系 统 ， 
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图 7-39 主页 面 的 浏览 效果 
ES ED 在 “查询 主题 ”文本 框 中 输入 “校园 ”关键 词 并 单 击 “ 查 询 ” 按 钮 ， 结 果 显 
示 ， 在 查询 结果 页 面 中 只 包含 有 关 “ 校 园 ” 的 最 新 新 闻 主 题 ， 这 样 ， 查 询 功能 就 
设计 完成 了 ， 效 果 如 图 7-40 所 示 。 


文件 四 ”编辑 EE) 查看 中 
过 直 四 箭 Mttp;//127.0.0.1:800/news/indexl. php 




















图 7-40 测试 查询 的 效果 
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3.2 新 闻 分 类 页 面 的 设计 


新 闻 分 类 页 面 type.php 用 于 显示 每 个 新 闻 分 类 的 页 面 , 当 访 问 者 单 击 index1.php 页 面 
中 的 任何 一 个 新 闻 分 类 标题 时 ,都 会 打开 相应 的 新 闻 分 类 页 面 , 新 闻 分 类 页 面 的 设计 效果 
如 图 7-41 所 示 。 


文件 如 编辑 上 查看) 收藏 中 工具 四 帮助 iD 
起 址 四 ) | 罩 http://127.0.0 1:800/ners/type php 


记录 1 到 2( 总 共 习 
新 闻 标 题 : 测试 校内 新 闻 
新 闻 标 题 : 测试 国内 新 闻 








7-41 新 闻 分 类 页 面 的 效果 


详细 的 操作 步骤 说 明 如 下 。 

ED 创建 type.php 页 面 ， 输 入 网 页 标题 “新 闻 分 类 ”， 在 页 面 中 插入 一 个 3x1 表 
格 A， 宽 度 为 768， 居 中 对 齐 ， 背 景色 为 性 FFFFF， 其 他 默认 。 第 一 行 插入 图 片 
images/top.gif， 第 三 行 插入 图 片 images/di.gif。 

ESDy 在 表格 A 的 第 二 行 单元 格 中 插入 一 个 1x1 表格 B， 宽 度 为 100%， 单 元 格 高 度 
为 192， 其 他 默认 。 按 两 次 Enter 键 ， 再 插入 一 个 1x1 表格 C， 宽 度 为 100%， 其 
他 默认 。 输 入 文字 “对 不 起 ， 此 新 闻 分 类 中 没有 任何 新 闻 ”。 

EEJRe) 在 表格 B 中 插入 一 个 2x1 表格 D， 宽 度 为 100%， 其 他 默认 。 设 置 第 一 行 单元 
格 的 高 度 为 30， 输 入 文本 “记录 到 (总 共 )”， 设 置 第 二 行 单元 格 水 平 居中 对 齐 ， 
插入 一 个 2x1 表格 E， 宽 度 为 67%， 居 中 对 齐 ， 按 两 次 Enter 键 ， 再 插入 一 个 1x4 
表格 FE， 宽度 为 67%， 其 他 默认 。 在 4 个 单元 格 中 分 别 输入 文字 : “第 一 页 ”、 
“前 = 页 “下 一 页 “< “最 后 一 页 ”> 

ED 在 表格 E 中 插入 一 个 1x2 表格 G， 宽 度 为 100%， 第 一 列 列 宽度 为 80%， 其 他 
默认 。 在 第 一 列 的 单元 格 中 输入 文字 “新 闻 标题 ，”， 在 第 二 列 的 单元 格 中 输入 
文字 “详细 内 容 ”。 
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EUDp typephp 这 个 页 面 主要 是 显示 所 有 新 闻 分 类 标题 的 数据 ， 所 使 用 的 数据 表 是 
news， 单 击 “ 绑 定 ”面板 中 的 “增加 ”按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “记录 
集 (查询 )” 选 项 ， 在 打开 的 “记录 和 集 ” 对 话 框 中 进行 如 下 设置 : 

在 “名 称 ” 文 本 框 中 输入 “Recordsetl” 作 为 该 记录 集 的 名 称 。 

从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 象 “news”。 

从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 “news”。 

在 “ 列 ” 栏 中 选中 “全 部 ” 单 选 按钮 。 

设置 “筛选 ”的 条 件 为 “news id” 一 “=” 一 “URL 参数 ”一 “id”。 

设置 “排序 ”方法 为 “news id” 一 “升序 ”。 

设置 完成 后 ， 单 击 [_ 志 时 ”| 按钮 ， 如 图 7-42 所 示 。 


了 宙 加 班 料 些 洲 峙 呈 巴 导语 届 大 


名 称 : Recordset1 











图 7-42 ” 绑 定 记录 集 的 设 定 


绑 定 记录 集 后 , 将 记录 集 的 字段 title 插入 到 type.php 网 页 表格 G 中 的 文字 “新 
闻 标 题 : ”的 后 面 ， 为 文字 “详细 内 容 ” 创 建 带 参数 链接 “newscontentphp? 
news_id=<?php echo $row_Recordsetl[‘news_id’]:; ?>”， 链 接 到 newscontent.php 网 
页 ， 如 图 7-43 所 示 。 

ES 为 了 显示 所 有 记录 ， 需 要 加 入 “服务 器 行为 ”中 的 “重复 区 域 ” 的 命令 ， 单 
击 type.php 页 面 中 需要 重复 的 表格 G， 如 图 7-44 所 示 。 

单 击 “ 应 用 程序 ”面板 中 “服务 器 行为 ”标签 上 的 [区 按钮， 从 弹出 的 菜单 中 ， 
选择 “重复 区 域 ”的 选项 ， 打 开 “ 重 复 区 域 ” 对 话 框 ， 设 定 一 页 显示 的 数据 为 10 
条 ， 如 图 7-45 所 示 。 

ED 单 击 [和 ] 掖 钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 的 区 域 左上 角 出 现 一 
个 “重复 ”灰色 标签 ， 表 示 已 经 完成 设置 。 
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7-43 ”插入 至 type.php 网 页 中 


记录 集 : | Recordset1 
mA: © lo | 
[9 





7-45 选择 一 次 可 以 显示 的 记录 数 


EC 在 “插入 ” 栏 的 “数据 ”类 型 中 ， 单 击 “ 记 录 集 分 页 ”区 四 按钮 ， 弹 出 “记录 
集 导航 条 ”对 话 框 ， 在 打开 的 对 话 框 中 选取 “Recordsetl ”记录 集 以 及 导航 条 的 显 
示 方 式 ， 然 后 单 击 L_ 确定 “ j 按 钮 回 到 编辑 页 面 ， 会 发 现 页 面 中 出 现 了 该 记录 集 的 
导航 条 ， 如 图 7-46 所 示 。 








新 闻 标 题 : {Recordsetl news_title} 

















图 7-46 添加 “记录 集 导 航 条 ” 


EDD 在 “插入 ” 栏 的 “数据 ”类 型 中 ， 单 击 “ 显 示 记 录 计 数 ”I 各- 工具 按钮 ， 从 弹 
出 的 菜单 中 ,选取 要 导航 状态 的 记录 集 为 “Recordset1”， 然 后 单 击 [确定] 按钮 
回 到 编辑 页 面 ， 会 发 现 页 面 中 出 现 了 该 记录 集 的 导航 状态 ， 如 图 7-47 所 示 。 
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图 7-47 添加 “记录 集 导航 状态 ” 

选取 文字 “详细 内 容 ”， 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 
览 文件 ”图 标 圆 ， 在 弹出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 
“newscontentphp”， 设 置 如 图 7-48 所 示 。 


选择 文件 名 自 : @) 文件 系统 
口 数 据 源 


站 点 和 服务 器 





查找 范围 中 ;| 已 ae 


同 mserverseripts | 





[a)login php 


司 @ 加 - 














文件 名 加 : 。 |aewscentent php 








文件 类 型 了 I) | 所 有 文件 t.*#) 











ML newscontent. php?news_id=<?php echo $row]| 





相对 于 : 文档 ¥) type. php 
在 站 点 定义 中 更 改 默认 的 链接 相对 于 





图 7-48 选择 链接 文件 


单 击 [ 区 数 .， ] 按 钮 ， 设 置 超级 链接 要 附带 的 URL 参数 的 名 称 和 值 。 将 参数 名 
称 命名 为 “new_ id”， 如 图 7-49 所 示 。 
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7-49 “参数 ”对 话 框 
选取 记录 集 有 数据 时 要 显示 的 数据 表格 ， 如 图 7-50 所 示 。 
| ee 人 ER 


rr 
| 新闻 标题 {Recordsetl news_title} 详细 内 容 























7-50 选择 要 显示 的 记录 


ED 单 击 “ 应 用 程序 ”面板 中 “服务 器 行为 ”标签 上 的 四 按钮 ， 从 弹出 的 下 拉 菜 
单 中 选择 “显示 区 域 ” 一 “如 果 记 录 集 不 为 空 则 显示 区 域 ” 选 项 ， 打 开 “ 如 果 记 
录 集 不 为 空 则 显示 区 域 ” 对 话 框 , 在 “记录 集 ” 中 选择 “Recordset”, 单 击 [_ 确定] 
按钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 显示 的 区 域 左 上 角 出 现 了 一 个 “如 果 符 
合 此 条 件 则 显示 ”的 灰色 卷 标 ， 表 示 已 经 完成 了 设置 ， 如 图 7-51 所 示 。 


大 c:Vapache\htdoesinewa\type cho -Ox 
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图 7-51 完成 设置 后 的 编辑 页 面 
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ED 输入 “对 不 起 ， 此 新 闻 分 类 中 没有 任何 新 闻 ” 说 明文 字 ， 同 时 选取 记录 集 没 
有 数据 时 要 显示 的 数据 表格 ， 如 图 7-52 所 示 。 
时 二 起 ， 此 新 闻 劳 类 中 投 有 尾 癌 新 闻 
图 7-52 ”选择 没有 数据 时 显示 的 区 域 


ED 单 击 “ 应 用 程序 ”面板 中 的 “服务 器 行为 ”标签 上 的 国术 钮 ， 从 弹出 的 下 拉 
菜单 中 选择 “显示 区 域 ” 一 “如 果 记 录 集 为 空 则 显示 区 域 ”选项 ， 在 “记录 集 ” 
中 选择 “Recordset1”， 再 单 击 [ 确定 “按钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 
显示 的 区 域 左 上 角 出 现 了 一 个 “如 果 符 合 此 条 件 则 显示 ”的 灰色 卷 标 ， 表 示 已 经 
完成 设置 ， 效 果 如 图 7-53 所 示 。 


守 岂 加 弄 特 瞪 淋 午 咀 画 于 全 霸 项 
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图 7-53 完成 设置 后 的 编辑 页 面 
到 这 里 ， 新 闻 分 类 页 面 type.php 的 设计 与 制作 就 已 经 完成 了 。 


3.3 ”新 闻 内 容 页 面 的 设计 


新 闻 内 容 页 面 newscontent.php 用 于 显示 每 一 条 新 闻 的 详细 内 容 ， 这 个 页 面 设计 的 重点 
在 于 如 何 接 收 主页 面 indexl.php 和 typephp 传递 过 来 的 参数 ， 并 根据 这 个 参数 显示 数据 库 
中 相应 的 数据 。 新 闻 内 容 页 面 的 设计 效果 如 图 7-54 所 示 。 
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到 http://127-.0.0.1: 














PHP 新 闻 系 统 ， 


新闻 标题 : 测试 校内 新 弛 
新 闻 内 容 : 这 是 而 试 术 辐 内 新 闻 





图 7-54 ”新闻 内 容 页 面 的 设计 效果 


详细 操作 步 又 如 下 。 

创建 “newscontent.php” 页 面 。 首 先 在 页 面 中 插入 一 个 3x1 表格 A， 宽 768， 
居中 对 齐 , 背景 色 为 本 FFFFF， 其 他 默认 。 在 第 一 行 的 单元 格 中 插入 images/top.gif 
图 片 ,在 第 三 行 的 单元 格 中 插入 images/di.gif 图 片 , 在 第 二 个 单元 格 中 插入 一 个 1x1 
表格 B， 宽 768， 边 框 为 0， 其 他 默认 。 

在 表格 B 中 插入 一 个 3x2 表格 C， 宽 768， 列 宽 分 别 是 394、374。 在 表格 第 
一 行 的 第 一 个 单元 格 中 输入 文字 “新 闻 标 题 : ”， 在 表格 第 一 行 的 第 二 个 单元 格 
中 输入 文字 “加 入 时 间 : ”， 合 并 第 二 、 第 三 行 的 单元 格 ， 在 合并 后 的 第 二 行 单 
元 格 中 输入 文字 “新 闻 内 容 : ”， 效 果 如 图 7-55 所 示 。 
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图 7-55 设计 新 闻 内 容 页 面 
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单 击 “ 绑 定 ” 面 板 中 的 [本 按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “记录 集 (查询 )” 选 


项 ， 在 弹出 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 : 

在 “名 称 ” 文 本 框 中 输入 “Recordsetl ”作为 该 记录 集 的 名 称 。 

从 “连接 ”下 拉 列 表 框 中 ， 选 择 数据 源 连接 对 象 “news”。 

从 “表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 “news”。 
在 “ 列 ” 栏 中 选中 “全 部 ” 单 选 按钮 。 


设置 “筛选 ”条 件 为 “news id” 一 “=” 一 “URL 参数 ”一 “news id”。 


再 单 击 [ 确定 “按钮 后 ， 就 完成 设 定 了 ， 如 图 7-56 所 示 。 





你: Recordsetl 
连接 ;|aevs 

表格 [es 

列 ; @ 全 部 。 〇 远 定 的 : 






































图 7-56 设 定 “ 记 录 集 ” 


了 宙 加 下 糙 洲 峙 呈 耳 避 ” 古 届 十 下 下 


绑 定 记 录 集 后 ， 将 记录 集 的 字段 插入 到 newscontentphp 页 面 中 的 适当 位 置 ， 


这 样 就 完成 了 新 闻 内 容 页 面 newscontent php 的 设置 ， 如 图 7-57 所 示 。 
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图 7-57 插入 绑 定 字段 
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BE 图 4| 后 台 管理 页 面 


新 闻 管理 系统 后 台 管 理 对 于 网 站 很 重要 ， 管 理 者 可 以 通过 这 个 后 台 增 加 、 修 改 或 删除 
新 闻 内 容 和 新 闻 的 类 型 ， 使 网 站 能 随时 维护 最 新 、 最 实时 的 信息 。 系 统管 理 登录 入 口 页 面 
的 设计 效果 如 图 7-58 所 示 。 





文件 中 编辑 是) 查看 Y) 收藏 @) 工具) 帮助 0 
地 址 中) | 莉 http://127.0.0.1:600/news/adnin/adnin_login php 二 注入 关键 司 搜索 口 国 | 











图 7-58 系统 管理 入 口 页 面 


4.1 后 台 管 理 登 录 


后 台 管理 主页 面 必须 受到 权限 管理 ， 可 以 利用 登录 账号 和 密码 来 判别 是 否 由 此 用 户 来 

实现 权限 的 设置 管理 。 

详细 的 操作 步骤 如 下 。 

ED 从 菜单 栏 中 选择 “文件 ”一 “新 建 ” 命 令 ， 创 建新 页 面 ， 输 入 网 页 标题 “ 管 
理 者 登录 ”， 从 菜单 栏 中 选择 “文件 ”一 “保存 ”命令 ， 在 站 点 news 文件 夹 中 的 
admin 文件 夹 中 ， 将 该 文档 保存 为 “admin loglnphp”。 

ED 从 菜单 栏 中 选择 “插入 ”一 “表单 ”一 “表单 ”命令 ， 插 入 一 个 表单 。 

ER) 将 光标 放置 在 该 表单 中 ， 从 菜单 栏 中 选择 “插入 ”一 “表格 ”命令 ， 打 开 “ 表 
格 ”对 话 框 ， 在 “ 行 数 ”文本 框 中 输入 需要 插入 表格 的 行 数 “4”。 在 “ 列 数 ” 文 
本 框 中 输入 需要 插入 表格 的 列 数 “2”。 在 “表格 宽度 ”文本 框 中 输入 “400” 像 
素 ， 其 他 的 选项 保持 默认 值 ， 如 图 7-59 所 示 。 

单 击 克 二 按钮， 在 该 表单 中 插入 了 一 个 4 行 2 列 的 表格 ， 选 择 表格 ， 在 
“属性 ”面板 中 设置 “对 齐 方式 ”为 “居中 对 齐 ”。 拖 动 鼠标 ， 选 中 第 1 行 表格 
的 所 有 单元 格 ， 在 “属性 ”面板 中 单 击 回 按钮 ， 将 第 1 行 表格 合并 。 用 同样 的 方 
法 将 第 4 行 合并 。 
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7-59 插入 表格 


EESDy 在 该 表单 的 第 1 行 中 输入 文字 “新 闻 后 台 管 理 中 心 ”， 在 表格 第 2 行 第 1 个 
单元 格 中 输入 文字 说 明 “账号 : ”， 在 表格 第 2 行 的 第 2 个 单元 格 中 单 击 “ 文 本 
域 ”按钮 所] ， 插 入 单行 文本 域 表 单 对 象 ， 定 义 文本 域名 为 “username”， 文 本 域 
的 属性 设置 如 图 7-60 所 示 。 








万 对 字符 宽度 作 | 。 | 类 型 @ 乔 行 Ej O 〇 多 行 D 。 〇 SEC) 类 加 | 无 ~| 
7 景 多 字符 数 | ”| 初始 值 I) ] 多 
口 本 用 四 ) 
USername DR 





7-60 ”账号 文本 域 的 设置 


在 表格 第 3 行 中 ， 输 入 文字 说 明 “密码 : ”， 在 表格 第 3 行 的 第 2 个 单元 格 
中 单 击 “ 文 本 域 ”按钮 区] ， 插 入 单行 文本 域 ， 定 义 文本 域名 为 “password”， 文 
本 域 属 性 的 设置 如 图 7-61 所 示 。 


属性 

















加 文本 域 字符 宽度 外 类 型 〇 单行 G) 加 多 行 吧 OSE 
assword | 最 多 字符 数 | 初始 值 加) ] 多 
口 禁 用 名 
password 口 六 四 





图 7-61 密码 文本 域 的 设置 


ED 单 击 选择 第 4 行 单元 格 ， 执 行 两 次 “插入 ”一 “表单 ”一 “按钮 ”菜单 命令 ， 
插入 两 个 按钮 ， 并 分 别 在 “属性 ”面板 中 进行 属性 变更 ， 一 个 为 登录 时 用 的 “ 提 
交 表 单 ” 选 项 ， 一 个 为 “ 重 设 表单 ”选项 ，“ 属 性 ”的 设置 如 图 7-62 所 示 。 


253 > 


PHP+MySQL 





















































动态 网 站 设计 实用 教 竹 
属性 
| 按钮 名 称 值 如 | 登录 动作 四 提交 表单 G) ” 口 无 四 类 台 ) 无 YY 
subnitl 加重 设 表单 ) 
属性 
| 按钮 名 称 值 @) 重 置 动作 〇 提交 表单 GE) ” 口 无 中 类 包 ) 无 bd 
submit2 中 重 设 表单 区 ) 

















图 7-62 设置 按钮 的 名 称 和 属性 
TY 单 击 “应 用 程序 ”面板 中 的 “服务 器 行为 ”标签 上 的 [四 按钮 ， 从 弹出 的 菜单 
中 选择 “用 户 身份 验证 ”一 “登录 用 户 ” 选 项 ， 打 开 “ 登 录用 户 ” 对 话 框 ， 设 置 
如 果 不 成 功 将 返回 主页 面 “indexphp”， 如 果 成 功 ， 将 登录 后 台 管 理 主页 面 
“admin php”， 如 图 7-63 所 示 。 


:| forml 


: username 





: |password 
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: [password 


adnin php Er 





口 苇 到 前 一 个 URLC 如 果 它 存在 》 
: [index. php BE 
人 [用户 各 和 密码 

名 用 户 名 、 窗 码 和 访问 级 别 

获取 级 别 自 ， ;3 


























图 7-63 登录 用 户 的 设 定 
EEC 从 菜单 栏 选 择 “ 窗 口 ” 一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 ， 单 击 “ 行 为 ” 
面板 中 的 [zs 按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “检查 表单 ” 选项， 打开 “检查 表单 ” 
对 话 框 ， 设 置 usemame 和 password 文本 域 的 值 都 为 “必需 的 ”、 可 接受 “任何 东 
西 ”， 如 图 7-64 所 示 。 
EC 单 击 L_ 克 按钮 ， 回 到 编辑 页 面 ， 完 成 后 台 管 理 入 口 页 面 admin loginphp 
的 设计 与 制作 。 





本 ” d” (Ek) | 
= ne | 


值 ， 思 必需 的 








可 接受 ，@ 任何 东西 。 〇 数字 
O 〇 电子 邮件 地 址 〇 数 从 [ | 到 [| | 
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图 7-64 “检查 表单 ”对 话 框 


4.2 ”后 台 管 理 主页 面 


后 台 管 理 主页 面 是 管理 者 在 登录 页 面 验证 成 功 后 所 登录 的 页 面 ， 这 个 页 面 可 以 实现 新 
增 、 修 改 或 删除 新 闻 内 容 和 新 闻 分 类 的 内 容 ， 使 网 站 能 随时 保持 最 新 、 最 实时 的 信息 。 页 
面 的 结构 如 图 7-65 所 示 。 


LB nors php 
和 @ 此 页 面 可 能 具有 仅 可 由 服务 器 搜索 到 的 动态 相关 文件 。 搜 索 | 首 达 考 数 





PHP 新 闻 系 统 ， 














加 








谐 辟 二 阶 : : 
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图 7-65 后 台 管 理 主页 面 的 效果 


详细 操作 步 又 如 下 。 

创建 admin.php 页 面 ， 首 先 在 页 面 中 插入 一 个 3x1 表格 A， 宽 度 768， 居 中 对 
齐 ， 背 景色 为 性 FFFFF， 其 他 默认 。 在 第 一 行 的 单元 格 中 插入 图 片 images/top.gif， 
在 第 三 行 的 单元 格 中 插入 图 片 images/di.gif。 在 第 二 行 的 单元 格 中 插入 一 个 1x3 表 
格 B， 宽 768， 边 框 0， 其 他 默认 。 各 列 列 宽 分 别 是 : 266、496 和 6， 行 高 222。 
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在 表格 B 的 第 一 列 单元 格 中 插入 一 个 表格 C(1x1, 宽 95%, 高 222, 其 他 默认 )。 
在 表格 C 中 分 别 插入 表格 D(3x1， 宽 100%， 其 他 默认 )、E(1x2， 宽 100%， 其 他 
默认 )、F(2x1， 宽 100%， 其 他 默认 )。 

ERe) 在 表格 D 的 3 个 单元 格 中 分 别 输入 “新 闻 后 台 管 理 中 心 : ”、“ 添 加 新 闻 ” 
和 “添加 新 闻 分 类 ”文字 。 在 表格 E 的 3 个 单元 格 中 分 别 输入 “管理 员 你 好 ! ” 
和 “请 你 管理 新 闻 分 类 ! ”文字 。 在 表格 下 的 第 一 行 单元 格 中 输入 “类 型 管理 ”。 

ES 在 表格 B 的 第 二 列 单元 格 中 分 别 插入 一 个 表格 G(1x2， 宽 100%, 高 20， 其 他 
默认 ) 和 表格 H(1x4， 宽 90%， 其 他 默认 )。 在 表格 G 的 第 一 列 单元 格 ( 列 宽 70%) 
输入 文字 “标题 : ”， 在 第 二 列 单元 格 中 输入 文字 “[ 修 改 ] [删除 ]”， 居 中 对 齐 。 
在 表格 H 的 各 列 单元 格 中 分 别 输入 “第 一 页 ”、“ 前 一 页 ”、“ 下 一 页 ”和 “最 
后 一 页 ”文字 内 容 。 

创建 记录 集 “Re”。 单 击 “ 绑 定 ” 面板 上 的 [ 友 按 钮 ， 从 弹出 的 菜单 中 选择 “ 记 
录 集 (查询 )” 选 项 ， 在 “记录 集 ” 对 话 框 中 进行 如 下 设置 : 

在 “名 称 ”文本 框 中 输入 “Re” 作 为 该 记录 集 的 名 称 。 

从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 象 “news”。 

从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 “news”。 

在 “ 列 ” 栏 中 选中 “全 部 ” 单 选 按钮 。 

将 “排序 ”设置 为 “news id” 一 “降序 ”方式 。 

完成 的 设置 情况 如 图 7-66 所 示 。 


[ee ee。®。 














图 7-66 设 定 “ 记 录 集 ” 


绑 定 记录 集 后 , 将 Re 记录 集中 的 news title 字段 插入 到 admin php 网 页 中 的 适 
当 位 置 ， 如 图 7-67 所 示 。 
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7-67 ”把 记录 集 的 字段 插入 到 admin.php 网 页 中 
由 于 要 加 入 “重复 区 域 ” 命 令 , 所 以 首先 选择 需要 重复 的 表格 , 如 图 7-68 所 示 。 











图 7-68 选择 重复 的 区 域 
TE> 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”标签 上 的 [| 按钮 ， 从 弹出 的 
下 拉 菜 单 中 选择 “重复 区 域 ” 选 项 ， 打 开 “ 重 复 区 域 ” 对 话 框 ， 设 定 一 页 显示 的 
数据 为 10 条 记录 ， 如 图 7-69 所 示 。 

















图 7-69 设置 记录 集 显 示 的 条 数 


TY 单 击 [_ 右 | 校 钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 的 区 域 左上 角 出 现 了 一 
个 “重复 ”灰色 标签 ， 这 表示 已 经 完成 设 定 。 

在 “插入 ” 栏 的 “数据 ”类 型 中 ， 单 击 王 中 工具 按钮 ， 打 开 “ 记 录 集 导航 条 ?” 
对 话 框 ， 选 取 Re 记录 集 的 显示 方式 为 “文本 ”， 然 后 单 击 [确定 “按钮 回 到 编辑 
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页 面 ， 会 发 现 页 面 出 现 该 记录 集 的 导航 条 ， 如 图 7-70 所 示 。 
站 ES 
人 @ 此 页 面 可 能 及 有 仅 可 由 服务 加 拉 过 到 太 相 关 文件 和 计 | 站 这 世 娄 © 
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7-70 页 面 中 的 效果 


ES admin php 是 提供 管理 者 链接 至 新 闻 编辑 的 页 面 ， 然 后 进行 新 增 、 修 改 与 删除 
等 操作 ， 设 置 了 4 个 链接 ， 各 链接 的 设置 如 表 7-6 所 示 。 


表 7-6 admin.php 页 面 的 链接 设置 


链接 名 链接 的 页 面 
标题 字段 fre_ news title} newscontent.php 
添加 新 闻 news_add.php 
修改 news_upd.php 
删除 news_del.php 





胃 注意 : ”其 中 “标题 字段 {re news title}”、 “修改 ”及 “删除 ”的 链接 必须 传递 参数 
给 转 到 的 页 面 ， 这 样 ， 转 到 的 页 面 才能 够 根据 参数 值 从 数据 库 中 将 某 一 笔 数 
据 筛选 出 来 进行 编辑 。 
ES 首先 选取 “添加 新 闻 ”， 在 “属性 ”面板 中 将 它 链接 到 admin 文件 夹 中 的 
news_add.php 页 面 。 
EC) 选取 右边 栏 中 的 “修改 ”文字 ， 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 
单 击 “ 浏 览 文件 ”图 标 回 ， 在 弹出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 
news_upd.php， 如 图 7-71 所 示 。 
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选择 文件 名 自 : 人 ) 文件 系统 
口 数 据 源 


查找 范围 [): 回 sanin 





_notes 国 type_add php 
回 aanin php 回 tm。 aa php 
回 sanin login php 国 type_upd php 





文件 名 四: |news_upd php 
文件 类 型 了 [) | 所 有 文件 (+.*) 
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7-71 选择 链接 的 文件 


单 击 [要 数 .， | 按钮 ， 设 置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 。 将 参数 名 
称 命 名 为 “news_ id”， 如 图 7-72 所 示 。 

















名 称 


news_id 




















7-72 “参数 ”对 话 框 


ED 选取 “删除 ”文字 并 重复 上 面 的 操作 ， 要 转 到 的 页 面 改 为 news_delphp， 并 传 
递 新 闻 标 题 的 ID 参数 ， 如 图 7-73 所 示 。 

EEC 选取 标题 字段 (Re_news title} 并 重复 上 面 的 操作 ， 要 前 往 的 细节 页 面 改 为 
“newscontentphp” 并 传递 新 闻 参 数 ， 如 图 7-74 所 示 。 

EEC》 单 击 [_ 二 按钮 ， 完 成 转 到 详细 页 面 的 设置 ， 到 这 里 ， 己 经 完成 了 新 闻 内 
容 的 编辑 ， 现 在 来 设置 一 下 新 闻 分 类 ， 单 击 “ 绑 定 ” 面 板 上 的 鸭 按 钮 ， 从 弹出 的 
下 拉 菜 单 中 选择 “记录 集 (查询 )” 选 项 ， 在 “记录 集 ” 对 话 框 中 进行 如 下 设置 

在 “名 称 ” 文 本 框 中 输入 “Rel ”作为 该 记录 集 的 名 称 。 

从 “连接 ”下 拉 列 表 杠 中， 选择 数据 源 连接 对 象 “news”。 

从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 “newstype”。 

在 “ 列 ” 栏 中 选中 “全 部 ” 单 选 按钮 。 
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选择 文件 名 自 : 文件 系统 [站 点 根 目录 | 


侣 数据 源 站 点 和 服务 器 








查找 范围 红 ): 加 aanin 悦目 印 巴 四- 





局 motes 回 type_adad php 
轩 adanin php type_del. php 
adnin_login php 加 type_upd php 





news_upd. php 


文件 名 加: |news_del.php 
文件 类 型 区 ): | 所 有 文件 人. 要 














VEL: [news_del. php?news_id=<?php echo $row_Re[| 
相对 于 : | 文档 司 | adanin php 
在 站 点 定义 中 更 改 默认 的 链接 相对 于 


选择 文件 名 自 : 人 文件 系统 

LE 〇 数据 汤 

查找 范围 中 :| 已 news 

同 motes index!. php 
外 admin 加 login php 
(BComections 

所 data 

[Gainsees 

图 sanin php 








文件 名 中: [newscontent. php 
文件 类 型 I)， | 所 有 文件 人 .和 图 














wRL: | /newscontent. php?news_id=<?php echo $r, 
相对 于 : [文才 辣 adnin php 
在 站 点 定义 中 更 改 默认 的 链接 相对 于 





图 7-74 设置 传递 至 newscontent.php 


完成 的 设置 情况 如 图 7-75 所 示 。 


绑 定 记录 集 后 , 应 将 Rel 记录 集中 的 type_name 字段 插入 至 admin.php 网 页 中 


的 适当 位 置 ， 如 图 7-76 所 示 。 


加 入 “服务 器 行为 ”中 的 “重复 区 域 ”命令 ， 选 择 需要 重复 的 表格 ， 如 图 7-77 


所 示 。 












































闻 世 加 弄 特 瞪 淋 央 另 开导 时 A 








7-75 设置 “记录 集 ” 对 话 框 


[DW HD OO A BD 本 四 四 加 ga 和 | 
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7-76 ”插入 字段 至 admin.php 网 页 中 





图 7-77 选择 要 重复 的 一 列 


EPED》 单 击 “应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”标签 上 的 国 按 钮 ， 从 弹出 的 
下 拉 菜 单 中 选择 “重复 区 域 ”选项 ， 打 开 “ 重 复 区 域 ”对 话 框 ， 设 定 一 页 显示 的 
数据 为 “所 有 记录 ”， 如 图 7-78 所 示 。 

EPE 单 击 [_ 厂 | 校 钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 的 区 域 左上 角 出 现 了 一 
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个 “重复 ”灰色 标签 ， 这 表示 已 经 完成 了 设置 。 








图 7-78 设置 “重复 区 域 ” 对 话 框 


EPZ 首先 选取 左边 栏 中 的 “修改 ”文字 , 选择 admin 文件 夹 中 的 type_upd.php 链接 
并 传递 ype id 参数 ， 如 图 7-79 所 示 。 


选择 文件 名 自 : 加 文件 系统 
〇 数据 源 


查找 范围 f); 加 adnin 
国 type_add php 


国 type_del php 
ogin php 加 type_upd php 


文件 名 0D: [type_opd php 
文件 类型 0)， | 所 有 文件 G+ 


WRL: |type_upd php?news_id=<?php echo $row_Re[’ 


相对 于 ; [文档 | sanin php 
在 站 点 定义 中 更 改 默认 的 链接 相对 于 





7-79 ”设置 传递 至 type_upd.php 


四 也 SY 选取 “删除 ”文字 并 重复 上 面 的 操作 ， 要 前 往 的 细节 页 面 改 为 type_del.php 并 
传递 ype id 参数， 如 图 7-80 所 示 。 

ES 区》 再 选取 “添加 新 闻 分 类 ”， 在 “属性 ”面板 中 将 它 链 接 到 admin 文件 夹 中 的 
type_add.php 页 面 。 

ER 后 台 管 理 是 管理 员 在 后 台 管 理 入 口 页 面 admin_login.php 输入 正确 的 账号 和 密 
码 才 可 以 进入 的 一 个 页 面 ， 所 以 必须 限制 对 本 页 的 访问 功能 。 单 击 “ 应 用 程序 ” 
面板 群 组 中 “服务 器 行为 ”标签 中 的 [而 | 按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “用 户 身 
份 验证 ”一 “限制 对 页 的 访问 ”选项 ， 如 图 7-81 所 示 。 

EEEs 在 弹出 的 “限制 对 页 的 访问 ”对 话 框 中 ， 针 对 “基于 以 下 内 容 进行 限制 ” 选 
择 “ 用 户 名 和 密码 ”， 如 果 访 问 被 拒绝 ， 则 转 到 首页 indexphp， 如 图 7-82 所 示 。 
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选择 文件 各自: 文件 系统 
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type_del php7aevs ii=Gphp echo $row Re 





7-80 设置 传递 至 type_del.php 
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图 7-81 选择 “限制 对 页 的 访问 ” 


限制 对 页 的 访问 


基于 以 下 内 容 进 行 限制 : ” 表 户 加 入 39 
名 ”用户 名 、 窜 码 和 访问 是 别 
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图 7-82 “限制 对 页 的 访问 ”对 话 框 
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单 击 [确定 ”上 按钮 ， 就 完成 了 后 台 管理 主页 面 admin php 的 制作 。 
4.3 新 增 新 闻 页 面 
新 增 新 闻 页 面 是 news_add php， 页 面 效果 如 图 7-83 所 示 ， 实 现 了 插入 新 闻 的 功能 。 


号 浴 加 新 闻 - 了 icrospft Internet Explorer 
文件 旭 ” 忽 辑 中 ”查看 名 收藏 和 ) 工具 0) 帮助 如 
地 址 四 ) | 和 http://127.0.0 1:800/news/adnin/news_add php 








EE] .sammB 








7-83 ”新 增 新 闻 页 面 的 设计 


详细 操作 步骤 如 下 。 

ED 创建 news_add.php 页 面 ， 在 页 面 中 插入 表单 ， 表 单 内 插入 5x2 表格 ( 宽 650， 
边框 1， 居 中 对 齐 )。 合 并 表格 的 第 一 行 和 第 五 行 单元 格 ， 在 第 一 行 单元 格 中 输入 
文字 “请 添加 新 闻 : ”; 第 二 行 第 一 列 单元 格 输入 “新 闻 标 题 : ”， 第 二 列 单元 
格 插入 文本 域 (名 为 news_title)， 其 后 输入 “*” 并 设置 为 红色 ; 第 三 行 第 一 列 单元 
格 输入 “新 闻 分 类 : ”， 第 二 列 单元 格 插入 菜单 表单 (名 为 news_type)， 其 后 输入 
“* 作 者 : ”( 红 色 显 示 )， 插 入 文本 域 ， 输 入 “*”( 红 色 显 示 ); 第 四 行 第 一 列 单元 
格 输入 “新 闻 内 容 : ”， 第 四 行 第 二 列 单元 格 插入 文本 区 域 (名 为 news_content， 
字符 宽度 60， 行 数 20， 多 行 显示 ); 第 五 行 单元 格 插入 两 个 按钮 : “添加 ”( 名 为 
Submit)、“ 重 置 ”( 名 为 Submit2)， 其 后 输入 “* 带 * 号 为 必 填 项 目 ”( 第 一 个 “*” 
红色 显示 )。 

创建 记录 集 “Recordsetl ”， 单 击 “ 绑 定 ” 面 板 上 的 [四 | 按钮 ， 从 弹出 的 下 拉 菜 
单 中 选择 “记录 集 ( 查 询 )” 选 项 ， 打 开 的 “记录 集 ” 对 话 框 ， 如 图 7-84 所 示 。 
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守 岂 加 弄 特 瞪 淋 午 咀 画 亨 ”证 绸 大 





图 7-84 “记录 集 ” 对 话 框 
EC) 绑 定 记 录 集 后 ， 单 击 “ 新 闻 分 类 ”的 列表 菜单 ， 在 “新 闻 分 类 ”的 列表 菜单 
属性 面板 中 单 击 区 __ 动态 j 按 钮 ， 在 打开 的 “动态 列表 /菜单 ”对 话 框 中 进行 设 
置 ， 如 图 7-85 所 示 。 
动态 列表 /菜单 
;|"news_type” 在 表单 “fornl” 


: 转口 SIS 
值 标签 





: |Recordsetl 
: |type_id ~ 


: |type_nane Y 


: [2php echo $rbv_Recordset1["| 到 





图 7-85 “动态 列表 /菜单 ”对 话 框 


本 章 中 的 一 个 技术 重点 就 是 要 使 用 PHP 实现 自动 获取 系统 的 默认 时 间 ， 当 插 
入 新 闻 时 能 自动 生成 当时 的 时 间 。 方 法 是 绑 定 一 个 隐藏 字段 并 命名 为 news_date， 
切换 到 代码 行 ， 将 值 按 以 下 设置 ， 设 置 后 单 击 [_ 确 二 “| 按钮 : 


<input name="news date" type="hidden" id="news date" 
value="<?php date default timezone set('Asia/Beijing'); 
echo date("“Y-m-d"); 

?> // 设 置 时 间 格式 和 时 间 区 域 
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在 news_add php 编辑 页 面 ， 再 次 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ” 

标签 上 的 [可 按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “插入 记录 ”选项 ， 如 图 7-86 所 示 。 


| DW 广 计 D 疙 0 本 加 天 四 骨 汉 人 0 本币 向 第 和 癌 刘 和 0 | 










口 | 口外 @| 巴 回回 图 | 国 团 | 国 回 口 | 加 口 | 马 忆 台 旦 加 加 
ET 


We A ed 
i -EE 


me phy 
人 此 面 可 怠 呈 有 仅 可 服务 茵 于 未 到 动态 禄 天 文 迪 . 近 评 | 下 让 二 光 







































EE 
得 和 ED 动人 
请 Fg 


提交 和 G)， 〇 无 四 Ol 
ORRe @@) 
































图 7-86 选择 “插入 记录 ”选项 
设置 “插入 记录 ”对 话 框 ， 如 图 7-87 所 示 。 



































图 7-87 设置 “插入 记录 ”对 话 框 


国 T> 从 菜单 栏 中 选择 “窗口 ”一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 ， 单 击 “ 行 为 ” 
面板 上 的 [+ 按钮 ， 从 打开 的 下 拉 菜单 中 选择 “检查 表单 ” 选项， 打开 “检查 表单 ” 
对 话 框 ， 所 有 域 均 设置 值 为 “必需 的 ”、 可 接受 为 “任何 东西 ”， 如 图 7-88 所 示 。 
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input "news_title” (R) 
D3 

















值 : 





可 接受 : @O 任何 东西 。 〇 数字 
〇 ”电子 邮件 地 址 〇 数字 从 


和 于 友 丑 型 特 瞪 淋 央 另 亨 语 霸 匡 








7-88 “检查 表单 ”对 话 框 的 设置 
单 击 [确定 ”| 按钮 回 到 编辑 页 面 ， 就 完成 了 news_add.php 页 面 的 设计 。 


4.4 ”修改 新 闻 的 页 面 


修改 新 闻 页 面 news_upd.php 的 主要 功能 是 将 数据 表 中 的 数据 送 到 页 面 的 表单 中 进行 修 
改 ， 修 改 数据 后 再 将 数据 更 新 到 数据 表 中 ， 页 面 设计 如 图 7-89 所 示 。 


加 更 新 新 闻 - 了 icrosoft Internet Explorer 
文件 @) ”编辑 下 ) 查看 WW 收藏 人 工具 I) 帮助 0 
地 址 吧 | 御 http://127.0.0.1:800/news/adnin/news_upd. php <* 输 入 关 津 词 搜 索 口 
管理 员 ,你 好 4 请 你 修改 新 闻 ? 
新 闻 标题 : 
更 新 时 间 : 
新 闻 分 类 : 











图 7-89 修改 新 闻 页 面 的 设计 
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详细 操作 步骤 如 下 。 
打开 news_upd.php 页 面 ， 并 单 击 “ 绑 定 ”面板 上 的 [地 ] 按 钮 ， 从 弹出 的 下 拉 菜 
单 中 选择 “记录 集 (查询 )” 选 项 ， 打 开 的 “记录 集 ” 对 话 框 ， 如 图 7-90 所 示 。 


和 名称: Recordset1 

















7-90 “记录 集 ” 对 话 框 的 设置 


ED 用 同样 方法 ， 再 绑 定 一 个 记录 集 “Recordset2”， 在 对 话 框 中 的 设 定 如 图 7-91 
所 示 。 



































图 7-91 再 绑 定 一 个 记录 集 “Recordset2” 


国 于 BY 绑 定 记录 集 后 ， 将 记录 集 的 字段 插入 到 news_updphp 网 页 中 的 适当 位 置 ， 如 
7-92 所 示 。 其 中 加 入 一 个 隐藏 绑 定 字 段 news id。 

EEC 在 “更 新 时 间 ” 一 栏 中 必须 取得 系统 的 最 新 时 间 ， 方 法 与 上 面 加 隐藏 字段 取 
得 时 间 的 方法 一 样 ， 直 接 输 入 取得 系统 时 间 的 代码 ， 如 图 7-93 所 示 。 

单 击 “ 新 闻 分 类 ?的 列表 菜单 , 在 新 闻 分 类 的 列表 菜单 属性 面板 中 单 击 区 _a， ] 
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按钮 ， 在 打开 的 “动态 列表 /菜单 ”对 话 框 中 进行 设置 ， 如 图 7-94 所 示 。 


图 capacheihtdoesinevsiadatnvnems_sed pp 3 





























新 闻 分 类 总 作者 IRecordsetl 
{Recordset1. news_content} ~ 












































hody) Cforngfornl> VI 00x ~ lee9 x 43v ok/ 2 Unicode 0TT-6) 





图 7-92 字段 的 插入 


<input name="news date" type="text" id="news date" value="<?php 
date default timezone set('Asia/Beijing'); 

echo datre("Y-m-d"); 

?> 


类 型 @ 单 行 @) 。 〇 多 行 如 。 〇 窑 码 四 ”类 忆 | 无 ] 





default_tinezone_set(A] 这 




















来 自 记录 集 的 选项 |Recordset2 


值 : |type_id YY 
标签 :| type_nane 图 
je 了 于: [iD SEO Srov_Roeordsot3 





图 7-94 绑 定 “ 动 态 列表 /菜单 ” 
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完成 表单 的 布置 后 ， 要 在 news_updphp 这 个 页 面 加 入 “服务 器 行为 ”中 “更 
新 记录 ”的 设 定 , 在 news_upd.php 的 页 面 上 , 单 击 “应 用 程序 ”面板 群 组 中 的 “ 服 


务 器 行为 ”标签 的 [本 按钮， 从 弹出 的 下 拉 菜单 中 选择 “更 新 记录 ”选项 , 如 图 7-95 
所 示 。 





DW 7 莘 四 上田 这 看 WJ 狼 四 性 加 本 四 全 加油 名 训 由 各 四 | 有 ” 匡 加 靶 强 
EE 


EEE 因 回 加 | 各国 | 帮 加 | 回 吕 | 双 忆 马 居 马克 加 













Os EE 


ma opd pon x 


OD TDR C3 






























































图 7-95 加 入 “更 新 记录 ”命令 


在 打开 的 “更 新 记录 ”的 设 定 对 话 框 中 进行 设置 , 如 图 7-96 所 示 。 其 中 news_id 
设置 为 主键 。 



































图 7-96 “更 新 记录 ”对 话 框 
单 击 [_ 确定 ”按钮 ， 即 完成 修改 新 闻 页 面 的 设计 。 
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4.5 删除 新 闻 页 面 


删除 新 闻 页 面 news_del.php 和 修改 的 页 面 差 不 多 ， 如 图 7-97 所 示 。 其 方法 是 将 表单 中 
的 数据 从 站 点 的 数据 表 中 删除 。 


国 c:VapachevhtdoesVners\adaininees_del phps 二 加 其 


ERE ners. php 








半 蔬 丑 型 特 瞪 淋 肝 哎 画 亨 “全民 项 


员 ,你 好 ， 你 要 开除 此 新 闻 呈 ? 
加 是 : | 
闻 分 类 : | 作者 


新 闻 内 容 : 





























Chody> Cform#forml> [WN 丁 QQ foo% v735 x 388v 6 K/1 秒 Unicode (WTF-8) 





图 7-97 删除 新 闻 页 面 的 设计 


详细 操作 步骤 如 下 。 
ED) 打开 news_delphp 页 面 ， 单 击 “ 绑 定 ” 面 板 上 的 [本 按钮 ， 接 着 在 弹出 的 下 拉 
菜单 中 选择 “记录 集 (查询 )” 选 项 , 设置 打开 的 “记录 集 ” 对 话 框 ， 如 图 7-98 所 示 。 


: Recordset1 



































图 7-98 “记录 集 ” 对 话 框 
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用 同样 方法 再 绑 定 一 个 记录 集 ， 输 入 设 定 值 ， 如 图 7-99 所 示 。 


名 称 : Recordset2 
连接 : news 















































图 7-99 再 绑 定 一 个 记录 集 “Recordset2” 


ES 绑 定 记 录 集 后 ， 将 记录 集 的 字段 插入 到 news_delphp 网 页 中 的 适当 位 置 ， 其 
中 绑 定 隐藏 字段 为 news id， 如 图 7-100 所 示 。 
































邮 c:\apache\htdoczinews\adaininers_del.php = 
LTR ners php 和 
] [ER ， 你 好 ， 你 要 册 除 此 新 闻 吗 ? : 
出 m 标 题 : 。 RecordsetL nevs_title} 加 
新 闻 分 类 : 罗 作者 [HRecordsetl 
{Recordset1. news_content} 加 | 
| 
新 闻 内 容 : 
~ 
| |] [取消 | | 
(<body> [NI A lo0% ~735 x 335v 7K/1 秒 Unicode (UTF-8) 











7-100 ”字段 的 插入 


EEC 绑 定 记录 集 后 ， 单 击 “ 新 闻 分 类 ”的 菜单 ， 在 新 闻 分 类 的 菜单 属性 面板 中 单 
击 区 动态 .按钮 , 在 打开 的 “动态 列表 /菜单 ”对 话 框 中 进行 设置 ,如 图 7-101 
所 示 。 

TY 完成 表单 的 布置 后 ， 要 在 news_delphp 页 面 中 ， 加 入 “服务 器 行为 ”中 “ 删 
除 记录 ”的 设置 ， 单 击 “ 应 用 程序 ”面板 中 的 “服务 器 行为 ”标签 上 的 [了 由 按钮 ， 
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从 弹出 的 下 拉 菜 单 中 选择 “删除 记录 ”选项 ， 在 打开 的 “删除 记录 ”对 话 框 中 ， 
输入 设 定 值 ， 如 图 7-102 所 示 。 


动态 列表 /菜单 


: "select” 在 表单 “forml” 


: 加 日 


对 宙 加 理 糙 洲 峙 呈 巴 导语 届 大 


: |Recordset2 
: |type_id 
:| type_nane v 


: [<?php echo $row_Recordset2[ | 贸 





图 7-101 绑 定 “ 动 态 列表 /菜单 ” 


: | 主键 值 


连接 :news 





:news 














: [news_id 司 巴 


:| vRL 参数 | Inews_id 


adnin. php 





图 7-102 设置 “删除 记录 ”对 话 框 
TB 单 击 [_ 厂 _]| 校 钮 ， 完 成 删除 新 闻 页 面 的 设计 。 


4.6 ”新 闻 新 增 分 类 页 面 


新 增 新 闻 分 类 页 面 type_add.php 的 功能 是 将 页 面 的 表单 数据 新 增 到 newstype 数据 表 中 ， 
页 面 设计 如 图 7-103 所 示 。 
详细 的 操作 步骤 如 下 。 
ED 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”标签 中 的 [而 | 按钮， 从 弹出 的 下 
拉 菜 单 中 选择 “插入 记录 ”选项 ， 在 打开 的 “插入 记录 ”对 话 框 中 输入 设 定 值 ， 
如 图 7-104 所 示 。 
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国 c:\apache\htdocsinewsvadain\trpa_ada_ php -Ox 
Ders php 





和 @ 此 页 面 可 能 具有 奴 可 由 服务 器 搜索 到 后 35 访 相 关 文 件 。 控 圭 | 首选 孝 洲 




















dyy》 CEormgforaly <tabIeyKCtr》 <tdyKinputgtype nine [NIW A 100% v735 x 154v 5X11 秒 Unicode (UTF-6) 


图 7-103 新 增 新 闻 分 类 页 面 的 设计 























自 : | fornl 





:jnews 











:newstype 
“type id” 是 一 个 未 使 用 的 主键 。 
从 “FORMN. type_nane ”获取 什 








图 7-104 设 定 “ 插 入 记录 ” 

EDD9 选择 表单 ， 从 菜单 栏 中 选择 “窗口 ”一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 ， 
单 击 “行为 ”面板 中 的 [+ 按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “检查 表单 ”选项 ， 
打开 “检查 表单 ”对 话 框 ， 设 置 “ 值 ”为 “必需 的 ”、 可 接受 为 “任何 东西 ”， 
如 图 7-105 所 示 。 

















: 昌 寿 何 东西 。 〇 数字 
〇 ”电子 邮件 地 址 〇 数字 从 到 





图 7-105 设置 “检查 表单 ”对 话 框 
EDU) 单 击 [型 按钮 ， 完 成 type_addphp 页 面 的 设计 。 
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4.7 修改 新 闻 分 类 页 面 


修改 新 闻 分 类 页 面 type_upd.php 的 功能 是 将 数据 表 的 数据 送 到 页 面 的 表单 中 进行 修改 ， 
修改 数据 后 ， 再 更 新 至 数据 表 中 ， 页 面 设计 如 图 7-106 所 示 。 








国 c:Vapacheihtdocsinews\adain\trpa_upd phps = 
ETRE ners. php Tf 
©@ 


加 此 页 面 可 能 具有 人 羽 可 由 服务 器 搜索 到 的 动态 相关 文件 搜索 | 首选 寺 数 


闻 克 加 型 特 瞪 淋 肝 另 亨 ”证 对 项 























名 称 : | 
| [ 佛 改 ]】 [本 本 
图 
Chody> <form#form! > [RI A 100% v735 x 154v 3 K/1 秒 Unicode (UTF-8) 
7-106 ”修改 新 闻 分 类 页 面 的 设计 
详细 操作 步骤 如 下 。 


打开 type_upd.php 页 面 ， 并 单 击 “ 应 用 程序 ”面板 中 “ 绑 定 ” 标 签 的 [区 | 按钮 。 
接着 ， 在 弹出 的 下 拉 菜 单 中 选择 “记录 集 (查询 )” 选 项 ， 打 开 “ 记 录 集 ” 对 话 框 ， 
在 对 话 框 中 输入 设 定 值 ， 如 图 7-107 所 示 。 


名 称 : Recordset1 
连接 : news 











第 选 : |type_id 
|URL 参数 
排序 : 无 





图 7-107 “记录 集 ” 对 话 框 
EGG) 绑 定 记录 集 后 ， 将 记录 集 的 字段 插入 到 type_upd.php 网 页 中 的 适当 位 置 ， 如 
图 7-108 所 示 。 其 中 绑 定 一 个 隐藏 字段 为 ype_ id。 
EDNE) 完成 表单 的 布置 后 ， 要 在 type_updphp 这 个 页 面 加 入 “服务 器 行为 ”中 “更 新 
记录 ”的 设 定 ， 在 type_updphp 的 页 面 上 ， 单 击 “ 应 用 程序 ”面板 中 的 “服务 器 
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行为 ”标签 的 [二 | 按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “更 新 记录 ”选项 , 在 打开 的 “更 
新 记录 ”对 话 框 中 输入 设 定 值 ， 如 图 7-109 所 示 。 























司 c-\apachaihtdccsinawsladainltrpe_upd php = 
LT ec RR 了 
@ 此 页 面 可 能 具有 仅 可 由 服务 器 搜索 到 的 动态 相关 文件 。 搜 索 | 首选 孝 数 © 
| 请 修改 新 闻 分 类 : 

! 分 类 名 称 : {Recordset1. type_nane} | 加 

: 修改 ] [ 重 四 ] 

ee 
Chody> Cform#forml> RQ lo0% v735 x 154v 5K/1 秒 Unicode (UTF-8) 














7-108 ”字段 的 插入 

















值 ; | FORN, type_id 
提交 为 : | 整数 
在 更 新 后 , 转 到 ; dnin. php 





图 7-109 “更 新 记录 ”对 话 框 
EEC 单 击 [_ 砚 | 按钮 ， 完 成 修改 新 闻 分 类 页 面 的 设计 。 
4.8 删除 新 闻 分 类 页 面 


删除 新 闻 分 类 页 面 type_del.php 的 功能 ， 是 将 表单 中 的 数据 从 站 点 的 数据 表 newstype 
中 删除 。 详 细 操 作 步 骤 如 下 。 

ES 打开 type_delphp 页 面 ， 该 页 面 与 更 新 页 面 是 一 模 一 样 的 。 单 击 “ 应 用 程序 ” 
面板 中 “ 绑 定 ” 标 签 的 鸭 按 钮 。 从 弹出 的 下 拉 菜 单 中 选择 “记录 集 (查询 )” 选 项 ， 
打开 “记录 集 ” 对 话 框 ， 在 打开 的 “记录 集 ” 对 话 框 中 输入 设 定 值 ， 如 图 7-110 
所 示 。 

ESDy 绑 定 记 录 集 后 ， 将 记录 集 的 字段 插入 到 type_deLphp 网 页 中 的 适当 位 置 ， 如 
图 7-111 所 示 。 其 中 绑 定 一 个 隐藏 字段 为 type id。 
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名 称 : Recordset1 


























和 于 友 慎 型 特 瞪 淋 肝 咀 画 亨 ”证 届 大 





7-110 “记录 集 ” 对 话 框 




















人 ® c:\apeche\itaoos\nevs\adatn\t7De_ dl. shoe ox 
CL ners. ph 了 
请 修改 新 闻 分 类 : 
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7-111 ”字段 的 插入 


加 BY 完成 表单 的 布置 后 ， 要 在 type_del.php 这 个 页 面 加 入 “服务 器 行为 ”中 的 “ 删 
除 记录 ”的 设 定 ， 在 type_del.php 的 页 面 上 ， 单 击 “ 应 用 程序 ”面板 中 的 “服务 器 
行为 ”标签 的 [区 按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “删除 记录 ”选项 ,在 打开 的 “ 删 
除 记 录 ” 对 话 框 中 输入 设 定 值 ， 如 图 7-112 所 示 。 











图 7-112 “删除 记录 ”对 话 框 


这 样 ， 一 个 实用 的 新 闻 管理 系统 就 开发 完毕 了 。 读 者 可 以 尝试 将 本 例 开发 新 闻 管 理 系 
统 的 方法 应 用 到 实际 的 大 型 网 站 建设 中 去 。 
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